Apache Commons DbUtils工具包使用介紹


這篇文章主要介紹了Apache Commons DbUtils工具包使用介紹,本文介紹了DBUtils是什么東西、熟悉DBUtils的一些問題、API介紹等內容,需要的朋友可以參考下
一、介紹

DBUtils是個小巧的JDBC輕量級封裝的工具包,其最核心的特性是在JDBC的基礎上做了一層封裝,主要是對結果集的封裝,可以直接將查詢出來的結果集封裝成JavaBean,旨在簡化JDBC代碼混亂與重復。

JDBC代碼開發,存在很多難點:
1)操作過程復雜,代碼操作一個模式,大量的重復。
2)結果集難以處理。
3)到處都強制檢查SQLException,影響代碼的美觀和可讀性。

二、熟悉DBUtils

在使用DBUtils之前,應該注意一些問題:
1)DBUtils是JDBC的簡單封裝,可以和JDBC混合使用。
2)DBUtils對結果集自動封裝為JavaBean是有着苛刻要求的:
必須滿足JavaBean的規范;
其次Bean的getter與setter方法的名字與結果集的列名必須一一對應;
不要求JavaBean的私有成員與表結果集列名一一對應。
3)DBUtils可以將結果集封裝為各種類型
主要有:Bean/List,Map/List/Map,數組/List<數組>,列/List<列>,這些類型。

對於Map的類型使用KeyedHandler作為結果集處理器,內層的Map是“列名-值"對,外層的Map是“主鍵-內層Map的引用”,但此處的主鍵不一定就是數據庫的主鍵,可以隨意指定。
4)DBUtils執行插入操作的時候,無法返回自增主鍵,這是一個很嚴重的問題,當然不能怪DBUtils,可以通過變通的方法來實現,比如在MySQL中,執行完了一個插入SQL后,接着執行SELECT LAST_INSERT_ID()語句,就可以獲取到自增主鍵。
5)DBUtils的性能和JDBC性能是一樣,測試過程中沒發現性能損失,擁有了很高性能的同時,而不失JDBC的靈活性。
6)對於JavaBean的成員類型定義,有一條原則那就是:盡可能使用包裝類型,而不要使用基本類型。

三、API介紹

1、org.apache.commons.dbutils包
DbUtils:一個為簡化JDBC操作的小類庫
AbstractQueryRunner:是抽象類,QueryRunner和AsyncQueryRunner類的基類。
AsyncQueryRunner:可插拔的方式執行SQL查詢,處理結果集。是線程安全的類。
BaseResultSetHandler:把結果集轉換成其它對象的擴展。
BeanProcessor:BeanProcessor匹
GenerousBeanProcessor:提供了從數據庫列名到JavaBean屬性之間的智能匹配。
ProxyFactory:產生JDBC接口的代理實現。
QueryLoader:屬性文件加載器,主要用於加載屬性文件中的SQL到內存中。
QueryRunner:使用可插拔的策略執行SQL查詢並處理結果集。
ResultSetHandler:把ResultSet轉換為別的對象的工具。
ResultSetIterator:包裝結果集為一個迭代器。
RowProcessor:將ResultSet行轉換為別的對象的工具。

2、org.apache.commons.dbutils.handlers包
AbstractKeyedHandler:KeyedHandler的抽象類。
AbstractListHandler:簡化ResultSetHandler類開發的抽象類,把結果集轉換成List。
ArrayHandler:把結果集中的第一行數據轉成對象數組。
ArrayListHandler:把結果集中的每一行數據都轉成一個對象數組,再存放到List中。
BeanHandler:將結果集中的第一行數據封裝到一個對應的JavaBean實例中。
BeanListHandler:將結果集中的每一行數據都封裝到一個對應的JavaBean實例中,存放到List里。
BeanMapHandler:實現了Bean返回Map集合。結果集所有的行都會轉換成Bean,並根據指定的Key存儲到Map中。

文章來源:http://www.iis7.com/b/ssyqdq/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM