JAva Dbutilsツールクラスライブラリ


一:Dbutilsとは何ですか.
     Dbutils:主にJDBCのコードをカプセル化し、dao層の操作を簡素化します.
     役割:javaプログラマーを助け、Daoレイヤコードの簡単なフレームワークを開発します.
     フレームワークの役割:プログラマーを助け、プログラムの開発効率を高める.
     DbutilsはApache社から提供されています.
二:なぜDbutilsが必要なのですか.
     Dbutilsを使用する前に、Dao層で使用した技術はJDBCでした.では、JDBCの弊害を分析してみましょう.
          (1)データベースリンクオブジェクト、sql文操作オブジェクト、結果セットオブジェクトをカプセル化し、この3つのオブジェクトは繰り返し定義される
          (2)パッケージデータのコードが重複し、かつ操作が複雑で、コード量が大きい
          (3)リリースリソースのコード重複
           結果:(1)プログラマーは開発時に大量の重複労働があった.(2)開発の周期が長く、効率が低い
3:Dbutilsの3つのコアクラスの紹介:
     1:DbUtils:接続データベースオブジェクト----jdbc補助メソッドの集合クラス、スレッドセキュリティ
          構築方法:DbUtils()
          役割:接続を制御し、本屋を制御し、駆動負荷額のクラスを制御する.
     2:QueryRunner:SQL文の操作オブジェクトで、クエリ結果セットのカプセル化ポリシーを設定できます.スレッドは安全です.
          構築方法:
          (1)QueryRunner():データベースに関係のないQueryRunnerオブジェクトを作成し、後でデータベースを操作すると、トランザクションを手動で制御できるConnectionオブジェクトを手動で与える必要があります.
                    Connection.setAutoCommit(false);     手動管理トランザクションの設定
                    Connection.commit();     トランザクションのコミット
 
          (2)QueryRunner(DataSource ds):データベースに関連付けられたqueryRunnerオブジェクトを作成し、後でデータベースを操作するときにConnectionオブジェクトを必要とせず、トランザクションを自動的に管理します.
                    DataSource:データベース接続プールオブジェクト.
 
          コンストラクション関数と添削方法の組み合わせ:
     QueryRunner()
           update(Connection conn, String sql, Object... params)
           query(Connection conn, String sql, ResultSetHandler rsh, Object... params)
 
     QueryRunner(DataSource ds)     
           update(String sql, Object... params)
           query(String sql, ResultSetHandler rsh, Object... params)
 
(3)ResultSetHandle:データをカプセル化するポリシーオブジェクト------カプセル化結果セットのデータを別のオブジェクトに変換する
          ポリシー:オブジェクトにデータをカプセル化する方法(例:データベースをUserに保存、配列に保存、コレクションに保存)
     方法紹介:handle(ResultSet rs)
          備考:詳細はResultSet Handle実装クラス(4)結果セットを参照してください.
     ①ArrayHandler:     クエリー結果の最初のローデータをObject配列に保存
     ②ArrayListHandler     クエリーの結果を、各ローをObject配列にカプセル化し、リストセットにデータを格納します.
     ③BeanHandler     クエリー結果の最初のローデータをuserオブジェクトにカプセル化
     ④BeanListHandler     クエリー結果の各行をuserオブジェクトにカプセル化し、リストセットに格納します.
     ⑤ColumnListHandler     クエリ結果の指定カラムのデータをListコレクションにカプセル化する
     ⑥MapHandler     クエリー結果の最初のローデータをmap結合(key==カラム名、value==カラム値)にカプセル化
     ⑦MapListHandler     クエリー結果の各行をmapセット(key==列名,value==列値)にカプセル化し,mapセットをListセットに格納する
     ⑧BeanMapHandler     クエリー結果の各行のデータを、Userオブジェクトにカプセル化し、maoセットに格納します(key==列名、value==列値).
     ⑨KeyedHandler     クエリーの結果の各行のデータをmap 1(key==列名、value==列値)にカプセル化し、map 1セット(複数)をmap 2セット(1つのみ)に格納します.
     ⑩ScalarHandler     count、avg、max、min、sum......関数のような実行結果をカプセル化
四:実現コード
挿入します.削除します.変更.
        //1. insert     
		public void insert() throws SQLException {

			QueryRunner qr = new QueryRunner();

			String sql = "insert into tb_student(username, password) values (?, ?)";

			Object[] params = { "hello", 123 };

			qr.execute(conn, sql, params);

			DbUtils.close(conn);
		}

	
	//2. update     
		public void update() throws SQLException {

			QueryRunner qr = new QueryRunner();

			String sql = "update tb_student set username = ?, password = ? where id = ?";

			Object[] params = { "   ", 250, 3};

			int i = qr.execute(conn, sql, params);

			System.out.println(i);

			DbUtils.close(conn);
		}


	//3. delete     
		public void delete() throws SQLException {

			QueryRunner qr = new QueryRunner();

			String sql = "delete from tb_student where id = ?";

			int i = qr.execute(conn, sql, 5);

			DbUtils.close(conn);
		}
package com.hello.dbutils.resultSetHandler;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import org.apache.commons.dbutils.DbUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.ArrayHandler;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ColumnListHandler;
import org.apache.commons.dbutils.handlers.MapHandler;
import org.apache.commons.dbutils.handlers.MapListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;
import org.apache.commons.dbutils.handlers.ArrayListHandler;
import org.junit.Test;

import com.hello.dbutils.pojo.Student;
import com.hello.dbutils.utils.DataBaseUtils;

public class Demo {

	private static Connection conn = DataBaseUtils.getDataBaseConnection();

	@Test
	public void run() throws SQLException {
		// arrayHandler();
		// arrayListHandler();
		// BeanHandler();
		// BeanListHandler();
		// columnListHandler();
		// scalarHandler();
		// mapHandler();
		mapListHandler();
	}
	
	/**
	 * MapListHandler:                   Map    ,      key    value       。  ,     ,   List        。
	 * @throws SQLException
	 */
	public void mapListHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		List> mapList = qr.query(conn, sql, new MapListHandler());

		// 4.     
		for (Map map : mapList) {
			
			for (String key : map.keySet()) {
				
				System.out.print(map.get(key) + "  ");
			}
			
			//   
			System.out.println();
		}
		
		// 5.     
		DbUtils.close(conn);
	}
	
	/**
	 * MapHandler                    Map    ,      key    value       。
	 * @throws SQLException
	 */
	public void mapHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		Map map = qr.query(conn, sql, new MapHandler());

		// 4.     
		for (String key : map.keySet()) {
			
			System.out.print(map.get(key) + "  ");
		}
	
		// 5.     
		DbUtils.close(conn);
	}
	
	/**
	 * ScalarHandler:         ,   count(*)、sum(*),        。
	 * @throws SQLException
	 */
	public void scalarHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select count(*) from tb_student";

		// 3.    SQL      
		Long count = qr.query(conn, sql, new ScalarHandler());

		// 4.     
		System.out.println(count);
	
		// 5.     
		DbUtils.close(conn);
	}
	
	/**
	 * ColumnListHandler:                ,      List      。
	 * @throws SQLException
	 */
	public void columnListHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		List list = qr.query(conn, sql, new ColumnListHandler("username"));

		// 4.     
		for (Object obj : list) {
			
			System.out.println(obj);
		}

		// 5.     
		DbUtils.close(conn);
	}
	
	/**
	 * BeanListHandler:                    JavaBean  ,      JavaBean          。
	 * @throws SQLException
	 */
	public void BeanListHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		List stuList = qr.query(conn, sql, new BeanListHandler(Student.class));

		// 4.     
		for (Student stu : stuList) {
			
			System.out.println(stu);
		}
		
		// 5.     
		DbUtils.close(conn);
	}

	/**
	 * BeanHandler:                      JavaBean  。  ,    Student。
	 * @throws SQLException
	 */
	public void BeanHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		Student stu = qr.query(conn, sql, new BeanHandler(Student.class));

		// 4.     
		System.out.println(stu);

		// 5.     
		DbUtils.close(conn);
	}
	
	/**
	 * ArrayListHandler:                   Object[]    ,                     。
	 * @throws SQLException
	 */
	public void arrayListHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		List result = qr.query(conn, sql, new ArrayListHandler());

		// 4.     
		for (Object[] objs : result) {
			for (Object obj : objs) {
				System.out.print(obj + "\t");
			}

			//   
			System.out.println();
		}

		// 5.     
		DbUtils.close(conn);
	}

	/**
	 * ArrayHandler:                   Object[]    ,                   。
	 * 
	 * @throws SQLException
	 */
	public void arrayHandler() throws SQLException {

		// 1.    QueryRunner   
		QueryRunner qr = new QueryRunner();

		// 2.    SQL   
		String sql = "select * from tb_student";

		// 3.    SQL      
		Object[] result = qr.query(conn, sql, new ArrayHandler());

		// 4.     
		for (Object obj : result) {
			System.out.println(obj);
		}

		// 5.     
		DbUtils.close(conn);
	}

}