数据库的概念
- 在java中,数据库存储技术可分为如下几类:
- JDBC-Druid-DBUtils概念
- JDBC-Druid-DBUtils实现代码
- 比较一下 JDBC, dbutils, Mybatis 和 Hibernate
在java中,数据库存储技术可分为如下几类:
- JDBC直接访问数据库
- JDO技术(Java Data Object)
- 第三方工具 O/R工具,如Mybatis,Hibernate等
JDBC是java访问数据库的基石,JDO,Hibernate等只是更好的封装了JDBC
JDBC-Druid-DBUtils概念
JDBC(Java Database Connectivity) java和数据库的连接技术,sun公司推出的一套java应用程序访问数据库的技术规范。
数据库连接池 Druid
普通的JDBC数据库连接使用 DriverManager 来获取,但是会出现很多问题。为了解决传统开发中数据库的连接问题,使用数据库连接池负责分配、管理和释放数据库连接
Apache—DBUtils 是 Apache 组织提供的一个开源 JDBC工具类库,它是对JDBC的简单封装 封装了和数据库存取的一些方法
- DbUtils类 提供如关闭连接、装载JDBC驱动程序等常规工作的工具类
- QueryRunner类该类封装了SQL的执行,是线程安全的。
- ResultSetHandler该接口用于处理 java.sql.ResultSet,将数据按要求转换为另一种形式。ResultSetHandler 接口提供了一个单独的方法:Object handle (java.sql.ResultSet rs)该方法的返回值将作为QueryRunner类的query()方法的返回值。
JDBC-Druid-DBUtils实现代码
JDBC-Druid-DBUtils
package com.atguigu.dao;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import com.atguigu.utils.JDBCUtilsByDruid;
public class BasicDao<T> {
QueryRunner qr = new QueryRunner();
/*
* 功能: 通用的增删改方法,针对于任何表
*/
public int update(String sql,Object...param){
Connection connection = null;
try {
connection = JDBCUtilsByDruid.getConnection();
int update = qr.update(connection, sql, param);
return update;
} catch (Exception e) {
throw new RuntimeException(e);
}finally{
JDBCUtilsByDruid.close(null, null, connection);
}
}
/**
* 功能:返回单个对象,针对于任何表
* @param sql
* @param clazz
* @param params
* @return
*/
public T querySingle(String sql,Class<T> clazz,Object...params){
Connection connection = null;
try {
connection = JDBCUtilsByDruid.getConnection();
//执行查询
return qr.query(connection, sql, new BeanHandler<T>(clazz), params);
} catch (Exception e) {
throw new RuntimeException(e);
}finally{
JDBCUtilsByDruid.close(null, null, connection);
}
}
/**
* 功能:返回多个对象,针对于任何表
* @param sql
* @param clazz
* @param params
* @return
*/
public List<T> queryMulti(String sql,Class<T> clazz,Object...params){
Connection connection = null;
try {
connection = JDBCUtilsByDruid.getConnection();
//执行查询
return qr.query(connection, sql, new BeanListHandler<T>(clazz), params);
} catch (Exception e) {
throw new RuntimeException(e);
}finally{
JDBCUtilsByDruid.close(null, null, connection);
}
}
/**
* 功能:返回单个值
* @param sql
* @param params
* @return
*/
public Object scalar(String sql,Object...params){
Connection connection = null;
try {
connection = JDBCUtilsByDruid.getConnection();
//执行查询
return qr.query(connection, sql, new ScalarHandler(),params);
} catch (Exception e) {
throw new RuntimeException(e);
}finally{
JDBCUtilsByDruid.close(null, null, connection);
}
}
}
比较一下 JDBC, dbutils, Mybatis 和 Hibernate
JDBC: 原生访问数据库的方式, 其它三个都是对 JDBC 不同程度的包装 访问数据库比较麻烦, 代码重复度极高
dbutils: 是对jdbc进行了相对简单的包装, 主要就是能自动封装查询结构 集, 需要在代码中写 sql 语句
Mybatis: 进一步封装 jdbc, Sql 语句写在配置文件中, 面向对象操作, 有一 二级缓存功能
Hibernate: 对 jdbc 封装得最彻底的框架, 纯面向对象, 可以不用写 SQL