前言
JDBCTamplate是Spring框架对JDBC的简单封装。提供了一个JDBCTemplate对象简 化JDBC的开发。JDBCTemplate依赖于数据源DataSource 。创建JDBCTemplate对象,只需要new一个JDBCTemplate,然后将我们在JDBCUtils创建的连接池对象DataSource作为参数传入即可。例如:JDBCTemplate template = new jdbcTemplate(DataSource);
一、使用步骤
1.导入jar包
在使用JDBCTemplate之前,需要导入相关的jar包,因为在这我使用的是c3p0 jdbcTemplate ,所以需要导入JDBCTemplate jar包5个+c3p0 jar包2个 + 数据库驱动包。
导入的jar包有如下(示例):
2.常用方法
调用JDBCTemplate的方法来完成CRUD的操作
>1. update():执行DML语句。增删改语句。
> 2. queryForMap():将查询结果将结果集封装为map集合,将列名作为key,将值作为value,将这条记录封装为一个map集合。
注:查询的结果集长度只能是1。
> 3. queryForList():查询结果将结果集封装为List集合。
注:将每一条记录封装为一个Map集合,再将Map集合装载到List集合中。
>4. query():查询结果,将结果封装为JavaBean对象的list集合中。
>5. queryForObject:查询结果,将结果封装为对象。
3.代码示例
JdbcUtils工具类:
import com.alibaba.druid.pool.DruidDataSourceFactory;
import javax.sql.DataSource;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
/*
1. 声明静态数据源成员变量
2. 创建连接池对象
3. 定义公有的得到数据源的方法
4. 定义得到连接对象的方法
5. 定义关闭资源的方法
*/
public class JDBCUtils {
// 1. 声明静态数据源成员变量
private static DataSource ds;
// 2. 创建连接池对象
static {
// 加载配置文件中的数据
InputStream is = JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties");
Properties pp = new Properties();
try {
pp.load(is);
// 创建连接池,使用配置文件中的参数
ds = DruidDataSourceFactory.createDataSource(pp);
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
// 3. 定义公有的得到数据源的方法
public static DataSource getDataSource() {
return ds;
}
// 4. 定义得到连接对象的方法
public static Connection getConnection() throws SQLException {
return ds.getConnection();
}
// 5.定义关闭资源的方法
public static void close(Connection conn, Statement stmt, ResultSet rs) {
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {}
}
if (stmt != null) {
try {
stmt.close();
} catch (SQLException e) {}
}
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {}
}
}
// 6.重载关闭方法
public static void close(Connection conn, Statement stmt) {
close(conn, stmt, null);
}
}
JDBCTemplate实现类:
public class DaoRouteImpl implements DaoRoute {
private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
@Override
public int findTotalCount(int cid) {
String sql = "select count(*) from tab_route where cid = ?";
return template.queryForObject(sql, Integer.class, cid);
}
@Override
public List<Route> findByPage(int cid, int start, int pageSize) {
String sql = "select * from tab_route where cid = ? limit ? , ?";
return template.query(sql, new BeanPropertyRowMapper<Route>(Route.class), cid, start, pageSize);
}
}
总结
使用jdbc连接池之后,我们会发现连接对象的复用性更高了,程序整体运行的性能也更高了。但我们发现操作JDBC还是比较麻烦的,要定义SQL,执行SQL,设置参数,处理结果。而JDBCTemplate却帮我们大大的减少了我们所需的工作量。