时间:2021-07-01 10:21:17 帮助过:9人阅读
二、jdbctemplate的配置文件:spring-context-jdbctemplate.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation=" http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd"> <!--配置spring自带的数据源 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/test"></property> <property name="username" value="root"></property> <property name="password" value="root"></property> </bean> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"></property> </bean> </beans>
三、具体实现的service类:JdbcTemplateService
package com.test.database.jdbctemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Service; @Service public class JdbcTemplateService { @Autowired JdbcTemplate jdbcTemplate; public void testJdbcTemplate() { String sql = "select * from user"; System.out.println(jdbcTemplate.queryForList(sql)); } }
四、测试类:JdbcTemplateMain.java
package com.test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.test.database.jdbctemplate.JdbcTemplateService; public class JdbcTemplateMain { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("spring-context.xml", "spring-context-jdbctemplate.xml"); context.getBean(JdbcTemplateService.class).testJdbcTemplate(); } }
五、执行结果为(数据库有两条记录):
[{id=1, name=tim, password=tim}, {id=2, name=park, password=park}]
另外:配置文件中配置的数据源(dataSource)也可以是一个数据库连接池。
*************************************************************************************
下面分析一下JdbcTemplate是如何完成数据库操作的:
jdbcTemplate.queryForList(sql)
跳到JdbcTemplate类中: 下一步: @Override public List<Map<String, Object>> queryForList(String sql) throws DataAccessException { return query(sql, getColumnMapRowMapper()); } 下一步: @Override public <T> List<T> query(String sql, RowMapper<T> rowMapper) throws DataAccessException { return result(query(sql, new RowMapperResultSetExtractor<>(rowMapper))); } 下一步(进入query方法): @Override @Nullable public <T> T query(final String sql, final ResultSetExtractor<T> rse) throws DataAccessException { Assert.notNull(sql, "SQL must not be null"); Assert.notNull(rse, "ResultSetExtractor must not be null"); if (logger.isDebugEnabled()) { logger.debug("Executing SQL query [" + sql + "]"); } /** * Callback to execute the query. */ class QueryStatementCallback implements StatementCallback<T>, SqlProvider { @Override @Nullable public T doInStatement(Statement stmt) throws SQLException { ResultSet rs = null; try { rs = stmt.executeQuery(sql); return rse.extractData(rs); } finally { JdbcUtils.closeResultSet(rs); } } @Override public String getSql() { return sql; } } return execute(new QueryStatementCallback()); } 下一步: @Override @Nullable public <T> T execute(StatementCallback<T> action) throws DataAccessException { Assert.notNull(action, "Callback object must not be null"); Connection con = DataSourceUtils.getConnection(obtainDataSource()); //获取connection(算法骨架) Statement stmt = null; try { stmt = con.createStatement(); //获取statement(算法骨架) applyStatementSettings(stmt); T result = action.doInStatement(stmt); //执行具体的操作(延迟到子类的操作) handleWarnings(stmt); return result; } catch (SQLException ex) { // Release Connection early, to avoid potential connection pool deadlock // in the case when the exception translator hasn‘t been initialized yet. String sql = getSql(action); JdbcUtils.closeStatement(stmt); stmt = null; DataSourceUtils.releaseConnection(con, getDataSource()); con = null; throw translateException("StatementCallback", sql, ex); } finally { JdbcUtils.closeStatement(stmt);//关闭statement(算法骨架) DataSourceUtils.releaseConnection(con, getDataSource());//关闭connection(算法骨架) } }
通过上述代码分析可以看出,spring的JdbcTemplate为我们实现了模板流程和方法(即算法骨架),我们需要做的就是配置好JdbcTemplate的dataSource,并且将JdbcTemplate纳入spring的管理,然后编写具体的数据库访问逻辑就可以了。
一是为我们省了繁琐的通用流程,像获取关闭connection、statment;
二是为我们提供了非常丰富且优雅的api进行sql操作。
java数据库访问—JdbcTemplate方式(模板设计模式)
标签:classname password void 总结 ase 性能 jdb 完成 work