现象描述:
常规数据库数据查询都需要以下步骤:
-
确定连接的数据库类型《mysql,oracle,db2,moangdb,sqlservlet》
-
下载数据库驱动(http://mvnrepository.org),并把jar包添加到项目中
-
把数据库连接的驱动类加载到java虚拟机中
-
通过DriverManager类中getConnection方法获取到对应数据库连接对象
-
通过连接对象创建编译对象
-
通过编译对象想sql发出指令
-
接受并处理返回的结果
-
释放相关操作资源
简而言之就是四步:
- 注册驱动
- 连接数据库
- 执行sql语句
- 关闭连接,释放资源
通常每执行一次sql语句都需要进行上述的步骤,连接和关闭对数据库的资源耗费巨大。
解决:
则需要进行优化,减少关闭次数,资源在静态代码块加载完成。利用JdbcTemplate 进行更一步封装,利于日常开发。
以下为封装的工具类:
/*
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);
}
}
使用:
private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());
public List<Category> findAll() {
String sql = "select * from tab_category";
return template.query(sql,new BeanPropertyRowMapper<Category>(Category.class));
}