电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

淺析JDBC的使用方法

瀏覽:138日期:2022-08-26 08:43:54

1.使用步驟:

導(dǎo)包 加載驅(qū)動(dòng)類class.forName(....) DriverManager獲取sql對(duì)象 寫sql語句 Statement與prepareStatement不一樣的執(zhí)行sql語句,前者是直接sql對(duì)象 . 執(zhí)行語句,而后者是預(yù)處理,即在創(chuàng)建sql對(duì)象時(shí),就用sql語句,最后在用對(duì)象執(zhí)行操作。

2.JDBCUtils工具類:

就是把使用步驟的共性,提出來,放在一個(gè)類中,這樣以后就能直接調(diào)用創(chuàng)建sql對(duì)象的方法就行了。

值得一提的是,如果我們使用配置文件,擴(kuò)展性更好,在使用其他數(shù)據(jù)庫時(shí),我們只需要更改配置文件properties。獲取配置文件可以使用properties對(duì)象。獲取jar包的絕對(duì)路徑可以使用classLoader類加載器。這樣我們就不用自己添加路徑了。

public class JDBCUtils { private static String url; private static String user; private static String password; private static String driver; /** * 文件的讀取,只需要讀取一次即可拿到這些值。使用靜態(tài)代碼塊 */ static{ //讀取資源文件,獲取值。 try { //1. 創(chuàng)建Properties集合類。 Properties pro = new Properties(); //獲取src路徑下的文件的方式--->ClassLoader 類加載器 ClassLoader classLoader = JDBCUtils.class.getClassLoader(); URL res = classLoader.getResource('jdbc.properties'); String path = res.getPath(); //2. 加載文件 pro.load(new FileReader(path)); //3. 獲取數(shù)據(jù),賦值 url = pro.getProperty('url'); user = pro.getProperty('user'); password = pro.getProperty('password'); driver = pro.getProperty('driver'); //4. 注冊(cè)驅(qū)動(dòng) Class.forName(driver); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } } /** * 獲取連接 * @return 連接對(duì)象 */ public static Connection getConnection() throws SQLException { return DriverManager.getConnection(url, user, password); } /** * 釋放資源 * @param stmt * @param conn */ public static void close(Statement stmt,Connection conn){ if( stmt != null){ try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if( conn != null){ try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } /** * 釋放資源 * @param stmt * @param conn */ public static void close(ResultSet rs,Statement stmt, Connection conn){ if( rs != null){ try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if( stmt != null){ try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if( conn != null){ try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } }

3.DBC控制事務(wù)

在執(zhí)行sql語句時(shí),如果程序執(zhí)行過程中,發(fā)生了異常。比如有兩個(gè)sql語句,一個(gè)是轉(zhuǎn)賬操作,一個(gè)人存轉(zhuǎn)的這筆錢,如果第一個(gè)操作結(jié)束后發(fā)生了異常。那么這筆錢就會(huì)不翼而飛,所以為了避免這樣的情況,可以使用事務(wù)。

具體操作

開啟事務(wù):setAutoCommit( boolean autoCommit ) :調(diào)用該方法設(shè)置參數(shù)為false,即開啟事務(wù)。 提交事務(wù):commit( )當(dāng)所有sql都執(zhí)行完提交事務(wù)。 回滾事務(wù):rollback( ) 在catch中回滾事務(wù)。

public static void main(String[] args) { PreparedStatement pstmt1 = null; PreparedStatement pstmt2 = null; Connection con = null; try { con = JDBCUtils.getConnection(); //開啟事務(wù) con.setAutoCommit(false); //2.1 張三 - 500 String sql1 = 'update account set balance = balance - ? where id = ?'; //2.2 李四 + 500 String sql2 = 'update account set balance = balance + ? where id = ?'; pstmt1 = con.prepareStatement(sql1); pstmt2 = con.prepareStatement(sql2); //4. 設(shè)置參數(shù),sql語句里的問號(hào) pstmt1.setDouble(1,500);//填第一個(gè)數(shù)據(jù) pstmt1.setInt(2,1);//填第二個(gè)數(shù)據(jù) pstmt2.setDouble(1,500); pstmt2.setInt(2,2); //5.執(zhí)行sql pstmt1.executeUpdate(); // 手動(dòng)制造異常 int i = 3/0; pstmt2.executeUpdate(); //提交事務(wù) con.commit(); } catch (SQLException e) { e.printStackTrace(); } catch (Exception e){ try { con.rollback(); } catch (SQLException ex) { ex.printStackTrace(); } } finally{ JDBCUtils.close(con,pstmt1); JDBCUtils.close(con,pstmt2); }}

4.JDBC連接池

連接池,就是先創(chuàng)建好一些連接對(duì)象,要用的的時(shí)候,直接使用,提高了效率,用完之后,歸還給連接池,以便其他的使用。

c3p0連接池:

1.步驟:

導(dǎo)入jar包 (兩個(gè)) c3p0-0.9.5.2.jar mchange-commons-java-0.2.12.jar ,還需要導(dǎo)入數(shù)據(jù)庫驅(qū)動(dòng)jar包

2.定義配置文件:

名稱: c3p0.properties 或者 c3p0-config.xml。路徑:直接將文件放在src目錄下即可。

3.創(chuàng)建核心對(duì)象 數(shù)據(jù)庫連接池對(duì)象 ComboPooledDataSource

4.獲取連接: getConnection

代碼:

//1.創(chuàng)建數(shù)據(jù)庫連接池對(duì)象 DataSource ds = new ComboPooledDataSource(); //2. 獲取連接對(duì)象 Connection conn = ds.getConnection();

druid:

這個(gè)是阿里的,性能更好,效率更高。

1.步驟:

導(dǎo)入jar包 druid-1.0.9.jar

2.定義配置文件:

是properties形式的可以叫任意名稱,可以放在任意目錄下

3.加載配置文件。Properties

4.獲取數(shù)據(jù)庫連接池對(duì)象:通過工廠類來獲取 DruidDataSourceFactory

5.獲取連接:getConnection

//3.加載配置文件Properties pro = new Properties();InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream('druid.properties');pro.load(is);//4.獲取連接池對(duì)象DataSource ds = DruidDataSourceFactory.createDataSource(pro);//5.獲取連接Connection conn = ds.getConnection();

由于代碼還是冗長(zhǎng),重復(fù)率高,所以可以自定義個(gè)工具類:

public class JDBCUtils { //1.定義成員變量 DataSource private static DataSource ds ; static{ try { //1.加載配置文件 Properties pro = new Properties(); pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream('druid.properties')); //2.獲取DataSource ds = DruidDataSourceFactory.createDataSource(pro); } catch (IOException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } } /** * 獲取連接 */ public static Connection getConnection() throws SQLException { return ds.getConnection(); }

Spring JDBC

Spring框架對(duì)JDBC的簡(jiǎn)單封裝。提供了一個(gè)JDBCTemplate對(duì)象簡(jiǎn)化JDBC的開發(fā)

1.步驟:

導(dǎo)入jar包創(chuàng)建JdbcTemplate對(duì)象。依賴于數(shù)據(jù)源DataSource

JdbcTemplate template = new JdbcTemplate(ds);

2.調(diào)用JdbcTemplate的方法來完成CRUD的操作

update():執(zhí)行DML語句。增、刪、改語句queryForMap():查詢結(jié)果將結(jié)果集封裝為map集合,將列名作為key,將值作為value 將這條記錄封裝為一個(gè)map集合

注意:這個(gè)方法查詢的結(jié)果集長(zhǎng)度只能是1queryForList():查詢結(jié)果將結(jié)果集封裝為list集合

注意:將每一條記錄封裝為一個(gè)Map集合,再將Map集合裝載到List集合中query():查詢結(jié)果,將結(jié)果封裝為JavaBean對(duì)象

query的參數(shù):RowMapper

一般我們使用BeanPropertyRowMapper實(shí)現(xiàn)類。可以完成數(shù)據(jù)到JavaBean的自動(dòng)封裝new BeanPropertyRowMapper<類型>(類型.class)queryForObject:查詢結(jié)果,將結(jié)果封裝為對(duì)象

一般用于聚合函數(shù)的查詢

//2. 定義sql //1. 獲取JDBCTemplate對(duì)象private JdbcTemplate template = new JdbcTemplate(JDBCUtils.getDataSource());String sql = 'update emp set salary = 10000 where id = 1001';//3. 執(zhí)行sqlint count = template.update(sql);System.out.println(count);

這大大簡(jiǎn)化了我們curd的代碼量。

以上就是淺析JDBC的使用方法的詳細(xì)內(nèi)容,更多關(guān)于Java jdbc使用的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JDBC
相關(guān)文章:
主站蜘蛛池模板: 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 耐火砖厂家,异形耐火砖-山东瑞耐耐火材料厂 | 宏源科技-房地产售楼系统|线上开盘系统|售楼管理系统|线上开盘软件 | 超声波成孔成槽质量检测仪-压浆机-桥梁预应力智能张拉设备-上海硕冠检测设备有限公司 | 筛分机|振动筛分机|气流筛分机|筛分机厂家-新乡市大汉振动机械有限公司 | 无锡网站建设-做网站-建网站-网页设计制作-阿凡达建站公司 | 依维柯自动挡房车,自行式国产改装房车,小型房车价格,中国十大房车品牌_南京拓锐斯特房车 - 南京拓锐斯特房车 | 橡胶接头|可曲挠橡胶接头|橡胶软接头安装使用教程-上海松夏官方网站 | 南京种植牙医院【官方挂号】_南京治疗种植牙医院那个好_南京看种植牙哪里好_南京茀莱堡口腔医院 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 乐泰胶水_loctite_乐泰胶_汉高乐泰授权(中国)总代理-鑫华良供应链 | 304不锈钢无缝管_不锈钢管厂家 - 隆达钢业集团有限公司 | 团建-拓展-拓展培训-拓展训练-户外拓展训练基地[无锡劲途] | 下水道疏通_管道疏通_马桶疏通_附近疏通电话- 立刻通 | 越南专线物流_东莞国际物流_东南亚专线物流_行通物流 | Safety light curtain|Belt Sway Switches|Pull Rope Switch|ultrasonic flaw detector-Shandong Zhuoxin Machinery Co., Ltd | 方源木业官网-四川木门-全国木门专业品牌 | 水冷式工业冷水机组_风冷式工业冷水机_水冷螺杆冷冻机组-深圳市普威机械设备有限公司 | 除尘器布袋骨架,除尘器滤袋,除尘器骨架,电磁脉冲阀膜片,卸灰阀,螺旋输送机-泊头市天润环保机械设备有限公司 | 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 胃口福饺子加盟官网_新鲜现包饺子云吞加盟 - 【胃口福唯一官网】 | 沥青灌缝机_路面灌缝机_道路灌缝机_沥青灌缝机厂家_济宁萨奥机械有限公司 | 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | WTB5光栅尺-JIE WILL磁栅尺-B60数显表-常州中崴机电科技有限公司 | 【北京写字楼出租_写字楼租赁_办公室出租网/出售】-远行地产官网 | RO反渗透设备_厂家_价格_河南郑州江宇环保科技有限公司 | 屏蔽泵厂家,化工屏蔽泵_维修-淄博泵业| 油漆辅料厂家_阴阳脚线_艺术漆厂家_内外墙涂料施工_乳胶漆专用防霉腻子粉_轻质粉刷石膏-魔法涂涂 | 数显恒温油浴-电砂浴-高温油浴振荡器-常州迈科诺仪器有限公司 | 钢托盘,钢制托盘,立库钢托盘,金属托盘制造商_南京飞天金属制品实业有限公司 | 网优资讯-为循环资源、大宗商品、工业服务提供资讯与行情分析的数据服务平台 | 福建珂朗雅装饰材料有限公司「官方网站」 | 北京遮阳网-防尘盖土网-盖土草坪-迷彩网-防尘网生产厂家-京兴科技 | 空气弹簧|橡胶气囊|橡胶空气弹簧-上海松夏减震器有限公司 | 塑木弯曲试验机_铜带拉伸强度试验机_拉压力测试台-倾技百科 | 皮带式输送机械|链板式输送机|不锈钢输送机|网带输送机械设备——青岛鸿儒机械有限公司 | 昆山PCB加工_SMT贴片_PCB抄板_线路板焊接加工-昆山腾宸电子科技有限公司 | 天津市能谱科技有限公司-专业的红外光谱仪_红外测油仪_紫外测油仪_红外制样附件_傅里叶红外光谱技术生产服务厂商 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 土壤墒情监测站_土壤墒情监测仪_土壤墒情监测系统_管式土壤墒情站-山东风途物联网 | 天津仓库出租网-天津电商仓库-天津云仓一件代发-【博程云仓】 |