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......関数のような実行結果をカプセル化
四:実現コード
挿入します.削除します.変更.
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