更新時間:2023年01月29日11時10分 來源:傳智教育 瀏覽次數:
QueryRunner類簡化了執(zhí)行SQL語句的代碼,它與ResultsetHandler組合在一起就能完成大部分的數據庫操作,大大減少編碼量。
QueryRunner類提供了兩個構造方法,一個是默認的構造方法,一個是需要javax.sql.DataSource作為參數的構造方法。因此,在不用為一個方法提供一個數據庫連接的情況下,提供給構造器的DataSource就可以用來獲得連接。但是,在使用JDBC操作數據庫時,需要使用Connection對象對事務進行管理,因此如果需要開啟事務就需要使用不帶參數的構造方法。針對不同的數據庫操作,QueryRunner類提供了不同的方法,具體如下。
該方法用于執(zhí)行查詢操作,其中,參數params表示一個對象數組,該數組中每個元素的值都被用來作為查詢語句的置換參數。需要注意的是,該方法會自動處理PreparedStatement和ResultSet的創(chuàng)建和關閉。
值得一提的是,QueryRunner中還有一個方法是query(Connection conn,String sql,Object[]params,ResultSetHandler rsh)。該方法與上述方法唯一不同的地方就是參數的位置。Java1.5增加了新特性:可變參數??勺儏颠m用于參數個數不確定,類型確定的情況,Java把可變參數當作數組處理。但是,可變參數必須位于最后一項,所以此方法已過期。
該方法用于執(zhí)行查詢操作,與第一個方法相比,它不需要將Connection對象傳遞給方法,它可以從提供構造方法的數據源DataSource或使用的setDataSource()方法中獲得連接。
該方法用于執(zhí)行一個不需要置換參數的查詢操作。
該方法用來執(zhí)行插入、更新或者刪除操作,其中,參數params表示SQL語句中的置換參數。
該方法用于執(zhí)行插入、更新或者刪除操作,它不需要置換參數。