




已閱讀5頁(yè),還剩3頁(yè)未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
package hzvtc.util;import java.sql.Connection;import java.sql.DriverManager;import java.sql.SQLException;import java.util.ArrayList;import mons.dbutils.DbUtils;import mons.dbutils.QueryRunner;import mons.dbutils.ResultSetHandler;import mons.dbutils.handlers.BeanHandler;import mons.dbutils.handlers.BeanListHandler;import mons.logging.Log;import mons.logging.LogFactory;public class DbHelper private String dbms; / 數(shù)據(jù)庫(kù)類型private String dbmsDriver; / 數(shù)據(jù)庫(kù)驅(qū)動(dòng)private String host; / 主機(jī)private String port; / 端口private String db; / 數(shù)據(jù)庫(kù)名private String user; / 用戶名private String password; / 密碼private Class beanClass = null;private Connection conn = null;private final Log logger = LogFactory.getLog(DbHelper.class);/* 根據(jù)數(shù)據(jù)庫(kù)類型設(shè)置驅(qū)動(dòng)程序* param dbms 數(shù)據(jù)庫(kù)類型,如mysql、postgresql等*/private void fillDbmsDriver(String dbms) if (dbms.equalsIgnoreCase(postgresql) dbmsDriver = org.postgresql.Driver; else if (dbms.equalsIgnoreCase(mysql) dbmsDriver = org.gjt.mm.mysql.Driver;/* 根據(jù)數(shù)據(jù)庫(kù)類型設(shè)置端口* param dbms 數(shù)據(jù)庫(kù)類型*/private void fillDbmsPort(String dbms) if (dbms.equalsIgnoreCase(postgresql) port = 5432; else if (dbms.equalsIgnoreCase(mysql) port = 3306;/* 設(shè)置數(shù)據(jù)連接時(shí)需要的參數(shù)* param dbms 數(shù)據(jù)庫(kù)類型* param host 主機(jī)* param db 數(shù)據(jù)庫(kù)名* param user 用戶名* param password 密碼*/public DbHelper(String dbms, String host, String db, String user, String password) this.dbms = dbms; fillDbmsDriver(dbms); this.host = host; fillDbmsPort(dbms); this.db = db; this.user = user; this.password = password;/* 設(shè)置數(shù)據(jù)連接時(shí)需要的參數(shù)* param dbms 數(shù)據(jù)庫(kù)類型* param host 主機(jī)* param port 端口* param db 數(shù)據(jù)庫(kù)名* param user 用戶* param password 密碼*/public DbHelper(String dbms, String host, String port, String db, String user, String password) this.dbms = dbms; fillDbmsDriver(dbms); this.host = host; this.port = port; this.db = db; this.user = user; this.password = password;/* 加載驅(qū)動(dòng)*/public void connect() if (conn != null) return; String strConn = String.format(jdbc:%s:/%s:%s/%s, dbms, host, port, db); DbUtils.loadDriver(dbmsDriver); try conn = DriverManager.getConnection(strConn, user, password); catch (SQLException e) logger.error(Database connection failed!); logger.error(e.getMessage(); /* 關(guān)閉Connection*/public void close() try DbUtils.close(conn); conn = null; catch (SQLException e) logger.error(Database close failed!); logger.error(e.getMessage(); /* 根據(jù)無(wú)參sql語(yǔ)句進(jìn)行查詢,并返回一個(gè)對(duì)象,用于單條記錄的查詢* param sql * return Object*/public Object query(String sql) if (conn = null | beanClass = null) return null; QueryRunner run = new QueryRunner(); ResultSetHandler h = new BeanHandler(beanClass); Object result = null; try result = run.query(conn, sql, h); catch (SQLException e) (SQLException in + sql + ); logger.error(e.getMessage(); return result;/* 根據(jù)有參sql語(yǔ)句進(jìn)行查詢,并返回一個(gè)對(duì)象,用于單條記錄的查詢* param sql * param args * return Object*/public Object query(String sql, Object. args) if (conn = null | beanClass = null) return null; QueryRunner run = new QueryRunner(); ResultSetHandler h = new BeanHandler(beanClass); Object result = null; try result = run.query(conn, sql, args, h); catch (SQLException e) (SQLException in + sql + ); logger.error(e.getMessage(); return result;/* 根據(jù)無(wú)參sql語(yǔ)句進(jìn)行查詢,并返回一個(gè)數(shù)據(jù)集,用于多條記錄的查詢* param sql* return ArrayList*/public ArrayList queryRecords(String sql) if (conn = null | beanClass = null) return null; QueryRunner run = new QueryRunner(); ResultSetHandler h = new BeanListHandler(beanClass); ArrayList result = null; try result = (ArrayList) run.query(conn, sql, h); / obtain the quaried records catch (SQLException e) (SQLException in + sql + ); logger.error(e.getMessage(); return result;/* 根據(jù)有參sql語(yǔ)句進(jìn)行查詢,并返回一個(gè)數(shù)據(jù)集,用于多條記錄的查詢* param sql* param args* return*/public ArrayList queryRecords(String sql, Object. args) if (conn = null | beanClass = null) return null; QueryRunner run = new QueryRunner(); ResultSetHandler h = new BeanListHandler(beanClass); ArrayList result = null; try result = (ArrayList) run.query(conn, sql, args, h); System.out.println(result.size(); / obtain the quaried records catch (SQLException e) (SQLException in + sql + ); logger.error(e.getMessage(); return result;/* 根據(jù)無(wú)參sql語(yǔ)句進(jìn)行數(shù)據(jù)更新,并返回更新后影響的記錄數(shù)* param sql* return int*/public int update(String sql) if (conn = null) return 0; QueryRunner run = new QueryRunner(); int result = 0; try result = run.update(conn, sql); catch (SQLException e) (SQLException in + sql + ); logger.error(e.getMessage(); return result;/* 根據(jù)有參sql語(yǔ)句進(jìn)行數(shù)據(jù)更新,并返回更新后影響的記錄數(shù)* param sql* param args* return int*/public int update(String sql, Object. args) if (conn = null) return -1; QueryRunner run = new QueryRunner(); int result = 0; try result = run.update(conn, sql, args); catch (SQLException e) (SQLException in + sql + ); logger.error(e.getMessage(); return result;/* 設(shè)置存放查詢結(jié)果的Bean類,每個(gè)Bean類對(duì)象對(duì)應(yīng)一條查詢的結(jié)果記錄* param beanClass,如User.class*/public void setBeanClass(Class beanClass) this.beanClass = beanClass;/* 設(shè)置使用外部的Connection對(duì)象,如來(lái)自數(shù)據(jù)庫(kù)連接池的連接* param conn Connection對(duì)象*/public void setConn(Connection conn) this.conn = conn;Overrideprotected void finalize() throws Throwable / TODO Auto-generated method stub close(); super.finalize();DbTestpackage hzvtc.util.test;import hzvtc.util.DbHelper;import java.util.List;public class DbTest /* param args*/public static void main(String args) / TODO Auto-generated method stub int n = 3; DbHelper dh = new DbHelper(mysql, localhost, test, root, 123456); dh.connect(); dh.setBeanClass(User.class); /u是從數(shù)據(jù)庫(kù)查詢出來(lái)的記錄對(duì)象 User u = (User) dh.query(SELECT id,name,age,address FROM t_user WHERE id=9); /u2是從數(shù)據(jù)庫(kù)查詢出來(lái)的記錄對(duì)象 User u2 = (User) dh.query(SELECT id,name,age,address FROM t_user WHERE id=?, n); / users和user2存放著從數(shù)據(jù)庫(kù)查詢
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025至2030柴油車排氣管行業(yè)市場(chǎng)深度研究與戰(zhàn)略咨詢分析報(bào)告
- 甘肅省學(xué)業(yè)水平數(shù)學(xué)試卷
- 再生橡膠市場(chǎng)質(zhì)量需求分析考核試卷
- 費(fèi)縣五年級(jí)期末數(shù)學(xué)試卷
- 高2期末數(shù)學(xué)試卷
- 廣東高一上冊(cè)數(shù)學(xué)試卷
- 事故案例分析與借鑒應(yīng)急法律法規(guī)遵守考核試卷
- 高中學(xué)考數(shù)學(xué)試卷
- 倉(cāng)儲(chǔ)環(huán)境適應(yīng)性分析與改進(jìn)考核試卷
- 廣東省揭陽(yáng)市17學(xué)年高二政治下學(xué)期第一次階段考試試卷(含解析)
- 2022年綿陽(yáng)江油市社區(qū)工作者招聘考試模擬試題及答案解析
- 2021年中國(guó)美術(shù)學(xué)院輔導(dǎo)員招聘考試題庫(kù)及答案解析
- 初中道德與法治學(xué)科教學(xué)經(jīng)驗(yàn)交流
- 申辦出入境證件的函
- 安全評(píng)估收費(fèi)指導(dǎo)意見(jiàn)
- DB34-T 4289-2022城鎮(zhèn)檢查井蓋安裝管理技術(shù)規(guī)程
- 年產(chǎn)3萬(wàn)噸硫酸鉀,1.8萬(wàn)噸副產(chǎn)工業(yè)鹽項(xiàng)目建設(shè)可行性研究報(bào)告
- 貴州省建筑與裝飾工程計(jì)價(jià)定額(2023版)
- 發(fā)證機(jī)關(guān)所在地區(qū)代碼表
- 征地補(bǔ)償數(shù)據(jù)庫(kù)建設(shè)技術(shù)方案
- 水下封底混凝土計(jì)算及施工
評(píng)論
0/150
提交評(píng)論