数据库的概念

  • 在java中,数据库存储技术可分为如下几类:
  • JDBC-Druid-DBUtils概念
  • JDBC-Druid-DBUtils实现代码
  • 比较一下 JDBC, dbutils, Mybatis 和 Hibernate


在java中,数据库存储技术可分为如下几类:

  1. JDBC直接访问数据库
  2. JDO技术(Java Data Object)
  3. 第三方工具 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的简单封装 封装了和数据库存取的一些方法

  1. DbUtils类 提供如关闭连接、装载JDBC驱动程序等常规工作的工具类
  2. QueryRunner类该类封装了SQL的执行,是线程安全的。
  3. 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