当前位置:Gxlcms > 数据库问题 > java数据库访问—JdbcTemplate方式(模板设计模式)

java数据库访问—JdbcTemplate方式(模板设计模式)

时间:2021-07-01 10:21:17 帮助过:9人阅读

="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"> <!-- 配置组件自动扫描装配路径及筛选条件 --> <context:component-scan base-package="com.*"/> </beans>

二、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   

人气教程排行