




已閱讀5頁,還剩3頁未讀, 繼續免費閱讀
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
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; / 數據庫類型private String dbmsDriver; / 數據庫驅動private String host; / 主機private String port; / 端口private String db; / 數據庫名private String user; / 用戶名private String password; / 密碼private Class beanClass = null;private Connection conn = null;private final Log logger = LogFactory.getLog(DbHelper.class);/* 根據數據庫類型設置驅動程序* param dbms 數據庫類型,如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;/* 根據數據庫類型設置端口* param dbms 數據庫類型*/private void fillDbmsPort(String dbms) if (dbms.equalsIgnoreCase(postgresql) port = 5432; else if (dbms.equalsIgnoreCase(mysql) port = 3306;/* 設置數據連接時需要的參數* param dbms 數據庫類型* param host 主機* param db 數據庫名* 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;/* 設置數據連接時需要的參數* param dbms 數據庫類型* param host 主機* param port 端口* param db 數據庫名* 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;/* 加載驅動*/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(); /* 關閉Connection*/public void close() try DbUtils.close(conn); conn = null; catch (SQLException e) logger.error(Database close failed!); logger.error(e.getMessage(); /* 根據無參sql語句進行查詢,并返回一個對象,用于單條記錄的查詢* 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;/* 根據有參sql語句進行查詢,并返回一個對象,用于單條記錄的查詢* 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;/* 根據無參sql語句進行查詢,并返回一個數據集,用于多條記錄的查詢* 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;/* 根據有參sql語句進行查詢,并返回一個數據集,用于多條記錄的查詢* 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;/* 根據無參sql語句進行數據更新,并返回更新后影響的記錄數* 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;/* 根據有參sql語句進行數據更新,并返回更新后影響的記錄數* 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;/* 設置存放查詢結果的Bean類,每個Bean類對象對應一條查詢的結果記錄* param beanClass,如User.class*/public void setBeanClass(Class beanClass) this.beanClass = beanClass;/* 設置使用外部的Connection對象,如來自數據庫連接池的連接* param conn Connection對象*/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是從數據庫查詢出來的記錄對象 User u = (User) dh.query(SELECT id,name,age,address FROM t_user WHERE id=9); /u2是從數據庫查詢出來的記錄對象 User u2 = (User) dh.query(SELECT id,name,age,address FROM t_user WHERE id=?, n); / users和user2存放著從數據庫查詢
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 遼寧省營口市大石橋市水源鎮2024-2025學年高中畢業班質量檢測試題生物試題含解析
- 四川省成都市雙流棠湖中學2025年高三聯考數學試題(聯考)試題含解析
- 吉林省吉林市第七中學2025年初三教學質量檢查(二統)數學試題含解析
- 武漢傳媒學院《人體解剖與組織學》2023-2024學年第一學期期末試卷
- 陜西省西安電子科技中學2025屆下學期初三期末考試生物試題含解析
- 山西經貿職業學院《生物統計與試驗設計Ⅰ》2023-2024學年第二學期期末試卷
- 四川建筑職業技術學院《建設法規與實務》2023-2024學年第一學期期末試卷
- 蘇南京一中學2024-2025學年初三元月月考化學試題含解析
- 南京中醫藥大學《長沙文化研究》2023-2024學年第二學期期末試卷
- 江蘇海洋大學《和聲基礎》2023-2024學年第二學期期末試卷
- 2025年度河南省水務規劃設計研究有限公司人才招聘28人筆試參考題庫附帶答案詳解
- CJT156-2001 溝槽式管接頭
- 人力資源外包投標方案
- 09畢業設計任務書
- (通用)中考數學總復習 第三章 函數 第4節 反比例函數課件 新人教
- 屋面開洞施工方案,好(全面完整版)
- 涂層厚度檢測記錄(共10頁)
- 水書釋義字表
- 天文導航技術發展綜述
- 三甲醫院財務工作流程圖
- 4S店三表一卡標準模板
評論
0/150
提交評論