Apache Commons DbUtils工具包使用介紹
一、介紹
DBUtils是個(gè)小巧的JDBC輕量級(jí)封裝的工具包,其最核心的特性是在JDBC的基礎(chǔ)上做了一層封裝,主要是對(duì)結(jié)果集的封裝,可以直接將查詢出來的結(jié)果集封裝成JavaBean,旨在簡化JDBC代碼混亂與重復(fù)。
JDBC代碼開發(fā),存在很多難點(diǎn):
1)操作過程復(fù)雜,代碼操作一個(gè)模式,大量的重復(fù)。
2)結(jié)果集難以處理。
3)到處都強(qiáng)制檢查SQLException,影響代碼的美觀和可讀性。
二、熟悉DBUtils
在使用DBUtils之前,應(yīng)該注意一些問題:
1)DBUtils是JDBC的簡單封裝,可以和JDBC混合使用。
2)DBUtils對(duì)結(jié)果集自動(dòng)封裝為JavaBean是有著苛刻要求的:
必須滿足JavaBean的規(guī)范;
其次Bean的getter與setter方法的名字與結(jié)果集的列名必須一一對(duì)應(yīng);
不要求JavaBean的私有成員與表結(jié)果集列名一一對(duì)應(yīng)。
3)DBUtils可以將結(jié)果集封裝為各種類型
主要有:Bean/List<Bean>,Map/List<Map>/Map<Map>,數(shù)組/List<數(shù)組>,列/List<列>,這些類型。
對(duì)于Map<Map>的類型使用KeyedHandler作為結(jié)果集處理器,內(nèi)層的Map是“列名-值"對(duì),外層的Map是“主鍵-內(nèi)層Map的引用”,但此處的主鍵不一定就是數(shù)據(jù)庫的主鍵,可以隨意指定。
4)DBUtils執(zhí)行插入操作的時(shí)候,無法返回自增主鍵,這是一個(gè)很嚴(yán)重的問題,當(dāng)然不能怪DBUtils,可以通過變通的方法來實(shí)現(xiàn),比如在MySQL中,執(zhí)行完了一個(gè)插入SQL后,接著執(zhí)行SELECT LAST_INSERT_ID()語句,就可以獲取到自增主鍵。
5)DBUtils的性能和JDBC性能是一樣,測試過程中沒發(fā)現(xiàn)性能損失,擁有了很高性能的同時(shí),而不失JDBC的靈活性。
6)對(duì)于JavaBean的成員類型定義,有一條原則那就是:盡可能使用包裝類型,而不要使用基本類型。
三、API介紹
1、org.apache.commons.dbutils包
DbUtils:一個(gè)為簡化JDBC操作的小類庫
AbstractQueryRunner:是抽象類,QueryRunner和AsyncQueryRunner類的基類。
AsyncQueryRunner:可插拔的方式執(zhí)行SQL查詢,處理結(jié)果集。是線程安全的類。
BaseResultSetHandler:把結(jié)果集轉(zhuǎn)換成其它對(duì)象的擴(kuò)展。
BeanProcessor:BeanProcessor匹配列名到Bean屬性名,并轉(zhuǎn)換結(jié)果集列到Bean對(duì)象的屬性中。
Dbutils:一個(gè)JDBC輔助工具集合。
GenerousBeanProcessor:提供了從數(shù)據(jù)庫列名到JavaBean屬性之間的智能匹配。
ProxyFactory:產(chǎn)生JDBC接口的代理實(shí)現(xiàn)。
QueryLoader:屬性文件加載器,主要用于加載屬性文件中的SQL到內(nèi)存中。
QueryRunner:使用可插拔的策略執(zhí)行SQL查詢并處理結(jié)果集。
ResultSetHandler:把ResultSet轉(zhuǎn)換為別的對(duì)象的工具。
ResultSetIterator:包裝結(jié)果集為一個(gè)迭代器。
RowProcessor:將ResultSet行轉(zhuǎn)換為別的對(duì)象的工具。
2、org.apache.commons.dbutils.handlers包
AbstractKeyedHandler:KeyedHandler的抽象類。
AbstractListHandler:簡化ResultSetHandler類開發(fā)的抽象類,把結(jié)果集轉(zhuǎn)換成List。
ArrayHandler:把結(jié)果集中的第一行數(shù)據(jù)轉(zhuǎn)成對(duì)象數(shù)組。
ArrayListHandler:把結(jié)果集中的每一行數(shù)據(jù)都轉(zhuǎn)成一個(gè)對(duì)象數(shù)組,再存放到List中。
BeanHandler:將結(jié)果集中的第一行數(shù)據(jù)封裝到一個(gè)對(duì)應(yīng)的JavaBean實(shí)例中。
BeanListHandler:將結(jié)果集中的每一行數(shù)據(jù)都封裝到一個(gè)對(duì)應(yīng)的JavaBean實(shí)例中,存放到List里。
BeanMapHandler:實(shí)現(xiàn)了Bean返回Map集合。結(jié)果集所有的行都會(huì)轉(zhuǎn)換成Bean,并根據(jù)指定的Key存儲(chǔ)到Map中。
ColumnListHandler:將結(jié)果集中某一列的數(shù)據(jù)存放到List中。
KeyedHandler:將結(jié)果集中的每一行數(shù)據(jù)都封裝到一個(gè)Map里,然后再根據(jù)指定的key把每個(gè)Map再存放到一個(gè)Map里。
MapHandler:將結(jié)果集中的第一行數(shù)據(jù)封裝到一個(gè)Map里,key是列名,value就是對(duì)應(yīng)的值。
MapListHandler:將結(jié)果集中的每一行數(shù)據(jù)都封裝到一個(gè)Map里,然后再存放到List。
ScalarHandler:將結(jié)果集中某一條記錄的其中某一列的數(shù)據(jù)存成Object。
3、org.apache.commons.dbutils.wrappers包
SqlNullCheckedResultSet:在每個(gè)getXXX方法上檢查SQL NULL值的ResultSet包裝類。
StringTrimmedResultSet:刪除結(jié)果集中字符串前后空格的ResultSet包裝類。
四、重要類詳述
1、DbUtils類
DbUtils提供如關(guān)閉連接、裝載JDBC驅(qū)動(dòng)程序等常規(guī)工作的工具類,里面的所有方法都是靜態(tài)的。
主要方法如下:
1)public static void close(...) throws SQLException
DbUtils類提供了三個(gè)重載的close方法。這些方法檢查所提供的參數(shù)是不是NULL,如果為空,就關(guān)閉Connection、Statement和ResultSet。
2)public static void closeQuietly(...)
bUtils類提供了四個(gè)重載的closeQuietly方法。這一類方法不僅能在Connection、Statement和ResultSet為NULL情況下避免關(guān)閉,還能隱藏一些在程序中拋出的SQLEeception。
3)public static void commitAndCloseQuietly(Connection conn)
在連接內(nèi)提交SQL,然后關(guān)閉連接,并且在關(guān)閉連接時(shí)不拋出SQL異常。
4)public static boolean loadDriver(String driverClassName)
此方法載入并注冊JDBC驅(qū)動(dòng),如果成功就返回true,失敗返回false。使用該方法,無需捕捉ClassNotFoundException異常。
2、QueryRunner類
QueryRunner類簡化了SQL查詢,它與ResultSetHandler組合在一起使用可完成大多數(shù)數(shù)據(jù)庫操作,能夠大量減少代碼量。
QueryRunner類提供了兩個(gè)構(gòu)造方法
1)默認(rèn)的構(gòu)造方法
2)需要一個(gè)javax.sql.DataSource來作參數(shù)的構(gòu)造方法。
3、QueryRunner類的主要方法
1)public Object query(Connection conn, String sql, Object[] params, ResultSetHandler rsh) throws SQLException
執(zhí)行一個(gè)查詢操作,在此查詢中,對(duì)象數(shù)組中的每個(gè)元素值被用來作為查詢語句的置換參數(shù)。此方法會(huì)自行處理PreparedStatement和ResultSet的創(chuàng)建和關(guān)閉。
2)public Object query(String sql, Object[] params, ResultSetHandler rsh) throws SQLException
幾乎與第一種方法一樣;唯一的不同在于它不將數(shù)據(jù)庫連接提供給方法,并且它是從提供給構(gòu)造方法的數(shù)據(jù)源(DataSource) 或使用的setDataSource方法中重新獲得Connection。
3)public Object query(Connection conn, String sql, ResultSetHandler rsh) throws SQLException
執(zhí)行一個(gè)不需要置換參數(shù)的查詢操作。
4)public int update(Connection conn, String sql, Object[] params) throws SQLException
用來執(zhí)行一個(gè)更新(插入、更新或刪除)操作。
5)public int update(Connection conn, String sql) throws SQLException
用于執(zhí)行一個(gè)不需要置換參數(shù)的更新操作。
6)insert插入方法
7)batch批處理方法
相關(guān)文章
windows 10 + vwware+centos 6.5虛擬機(jī)系統(tǒng)安裝Tomcat
這篇文章主要介紹了windows 10 + vwware+centos 6.5虛擬機(jī)系統(tǒng)安裝Tomcat的相關(guān)資料,需要的朋友可以參考下2017-01-01
Linux下使用使用socket實(shí)現(xiàn)TCP服務(wù)端的示例代碼
套接字(socket)是 Linux 下的一種進(jìn)程間通信機(jī)制(socket IPC),它不僅支持同一主機(jī)的不同進(jìn)程間通信,還支持跨網(wǎng)絡(luò)的不同主機(jī)的進(jìn)程間通信,本文介紹了 Linux 下使用 socket 接口實(shí)現(xiàn) TCP 服務(wù)端的示例程序,需要的朋友可以參考下2024-03-03
apache偽靜態(tài)與iis偽靜態(tài)規(guī)則與配置區(qū)別介紹
本文章來總結(jié)一下關(guān)于apache偽靜態(tài)與iis偽靜態(tài)區(qū)別介紹,主要講到了一些規(guī)則的問題與配置區(qū)別,以后大家就可以直接在iis偽靜態(tài)轉(zhuǎn)換apache,反之也很簡單哦,需要了解的碰可以參考下2012-12-12
Apache 新站點(diǎn)目錄配置 SELinux 的方法
本文詳細(xì)介紹了如何使用SELinux保護(hù)Apache新站點(diǎn)目錄,包括確定默認(rèn)上下文、創(chuàng)建和設(shè)置新目錄的上下文、允許網(wǎng)絡(luò)連接以及驗(yàn)證配置,感興趣的朋友跟隨小編一起看看吧2024-11-11
Linux VPS及服務(wù)器更加安全之設(shè)置Putty SSH使用密鑰登錄
這篇文章主要介紹了Linux VPS及服務(wù)器更加安全之設(shè)置Putty SSH使用密鑰登錄,需要的朋友可以參考下2016-10-10
啟用 Apache Rewrite 重寫模塊的詳細(xì)過程
Apache的mod_rewrite是最強(qiáng)大的URL 操作模塊之一,使用 mod_rewrite,您可以重定向和重寫 url,這對(duì)于在您的網(wǎng)站上實(shí)現(xiàn) seo 友好的 URL 結(jié)構(gòu)特別有用,在本文中,我們將引導(dǎo)您了解如何在基于 Debian 和基于 RHEL 的系統(tǒng)上在 Apache 中啟用 mod 重寫,感興趣的朋友一起看看吧2025-02-02
bat腳本啟動(dòng)git bash窗口,并執(zhí)行命令方式
本文介紹了如何在Windows服務(wù)器上使用cmd啟動(dòng)jar包時(shí)出現(xiàn)亂碼的問題,并提供了解決方法——使用Git Bash窗口啟動(dòng)并設(shè)置編碼,通過編寫start.bat腳本,設(shè)置編碼為UTF-8,可以避免亂碼問題2024-12-12
Ubuntu cron日志開啟與查看的實(shí)現(xiàn)步驟
這篇文章主要介紹了Ubuntu cron日志開啟與查看的實(shí)現(xiàn)步驟的相關(guān)資料,希望通過本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10

