日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

淺析JDBC的使用方法

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

1.使用步驟:

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

2.JDBCUtils工具類(lèi):

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

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

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集合類(lèi)。 Properties pro = new Properties(); //獲取src路徑下的文件的方式--->ClassLoader 類(lèi)加載器 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語(yǔ)句時(shí),如果程序執(zhí)行過(guò)程中,發(fā)生了異常。比如有兩個(gè)sql語(yǔ)句,一個(gè)是轉(zhuǎn)賬操作,一個(gè)人存轉(zhuǎn)的這筆錢(qián),如果第一個(gè)操作結(jié)束后發(fā)生了異常。那么這筆錢(qián)就會(huì)不翼而飛,所以為了避免這樣的情況,可以使用事務(wù)。

具體操作

開(kāi)啟事務(wù):setAutoCommit( boolean autoCommit ) :調(diào)用該方法設(shè)置參數(shù)為false,即開(kāi)啟事務(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(); //開(kāi)啟事務(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語(yǔ)句里的問(wèn)號(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ù)庫(kù)驅(qū)動(dòng)jar包

2.定義配置文件:

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

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

4.獲取連接: getConnection

代碼:

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

druid:

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

1.步驟:

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

2.定義配置文件:

是properties形式的可以叫任意名稱(chēng),可以放在任意目錄下

3.加載配置文件。Properties

4.獲取數(shù)據(jù)庫(kù)連接池對(duì)象:通過(guò)工廠類(lèi)來(lái)獲取 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è)工具類(lèi):

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的開(kāi)發(fā)

1.步驟:

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

JdbcTemplate template = new JdbcTemplate(ds);

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

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

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

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

query的參數(shù):RowMapper

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

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

//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)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品国产欧美日韩| 欧美日韩1区2区3区| 欧美91在线| 国产亚洲人成a在线v网站| 日韩在线成人| 日韩精品亚洲专区| 日韩激情中文字幕| 国产日韩三级| 日本aⅴ精品一区二区三区| 亚洲精品福利| 日韩极品在线观看| 国产精品a级| 精品美女视频| 久久一区二区三区电影| 亚洲经典在线| 亚洲日本三级| 久久国产婷婷国产香蕉| 精品国产aⅴ| 久久精品电影| 欧美专区18| 最新国产精品| 国产亚洲欧美日韩精品一区二区三区| 日韩国产欧美三级| 欧美日韩1区| 久久亚洲精精品中文字幕| a天堂资源在线| 欧美日韩免费观看一区=区三区 | 日韩av电影一区| 久久精品72免费观看| 国产精品乱战久久久| 欧美成人a交片免费看| 亚州av乱码久久精品蜜桃| 最新亚洲国产| 国产一区精品福利| 国产真实久久| 国产亚洲毛片在线| 欧美一区激情| sm久久捆绑调教精品一区| 狠狠爱成人网| 国产伦精品一区二区三区在线播放| 精品久久视频| 在线精品小视频| 日韩av在线播放中文字幕| 久久精品人人| 黄色亚洲精品| 欧美激情麻豆| 欧美日韩免费观看一区=区三区 | 18国产精品| 亚洲啊v在线| 亚洲深爱激情| 久久久91麻豆精品国产一区| 亚洲成人一区| 国产精品欧美一区二区三区不卡| 午夜av成人| 日韩国产欧美视频| 亚洲高清二区| 国产精品色在线网站| 亚洲黄页一区| 精品伊人久久| 午夜一级久久| 国产一区二区三区国产精品| 爽好久久久欧美精品| 国产精品国产一区| 麻豆亚洲精品| 激情国产在线| 青青草国产精品亚洲专区无| 99精品视频精品精品视频| 欧美精品观看| 午夜久久一区| 麻豆国产精品| 一本综合精品| 日韩中文在线播放| 久久99久久久精品欧美| 国产精品毛片| 日韩中文首页| 国产精品地址| 久久先锋影音| 久久久久久久久丰满| 日韩高清国产一区在线| 欧美 日韩 国产精品免费观看| 国产精品毛片aⅴ一区二区三区| 99热精品在线| 日韩大片在线播放| 国产九九精品| 一二三区精品| 国产亚洲精品自拍| 久久免费国产| 久久久久久色 | 欧美日本久久| 日本大胆欧美人术艺术动态| 日韩美女一区二区三区在线观看| 青草国产精品| 免费人成网站在线观看欧美高清| 国产亚洲一区二区手机在线观看| 国产麻豆一区二区三区精品视频| 日韩中文字幕1| 精品欧美激情在线观看| 亚洲最新无码中文字幕久久| 国产精品入口久久| 青草国产精品| 亚洲一区有码| 红桃视频国产一区| 99久久精品费精品国产| 精品深夜福利视频| 国产精品黄色| 国产精品亚洲产品| 亚洲va久久| 在线观看视频免费一区二区三区| 91久久午夜| 国产精品av一区二区| 99久久精品网| 久久视频国产| 欧美影院三区| 91tv亚洲精品香蕉国产一区| 国产精品成久久久久| 久久久久伊人| 麻豆成人91精品二区三区| 欧美国产中文高清| 欧美一级二区| 欧美日韩精品一区二区三区在线观看| 亚洲精品乱码久久久久久蜜桃麻豆| 国产亚洲午夜| 欧美中文字幕| 亚洲人成网77777色在线播放| 久久国产精品久久久久久电车 | 日韩成人精品一区二区| 欧美激情国产在线| 亚洲黄色免费av| 少妇精品导航| 午夜免费一区| 另类av一区二区| 亚洲图片久久| 日韩一区二区三区高清在线观看 | 国产中文欧美日韩在线| 国产一区二区三区不卡视频网站 | 欧美日韩18| 你懂的国产精品| 精品三级av| 秋霞国产精品| 午夜一区在线| 久久精品xxxxx| 国产精品一区免费在线| 美女久久久久久| 岛国av在线网站| 天堂网av成人| 欧美网站在线| 免费成人av在线播放| 亚洲精品亚洲人成在线观看| 97久久中文字幕| 国产精品久久久久久久免费观看| 99久久精品国产亚洲精品| 国产亚洲毛片| 日韩av黄色在线| 国产一区二区三区四区五区| 日韩不卡免费高清视频| 亚洲免费影院| 日韩av网站在线免费观看| 精品一区二区男人吃奶| 国产不卡人人| 久久亚洲风情| 麻豆高清免费国产一区| 精精国产xxxx视频在线野外| 国产精品普通话对白| 日韩va欧美va亚洲va久久| 91视频久久| 亚洲欧美日韩在线观看a三区| 国产色噜噜噜91在线精品| 97在线精品| 日韩在线观看一区二区| 国产精品三级| 午夜久久美女| 国产亚洲一区二区三区啪| 日韩成人三级| 日本亚洲视频| 日韩天堂在线| 日韩三区四区| 欧洲一区二区三区精品| 亚洲婷婷丁香| 天堂√中文最新版在线| 免费成人在线视频观看| 精品国产乱码久久久| 亚洲欧美日韩国产一区二区| 美女国产精品久久久| 欧美另类专区| 美女视频网站久久| 丝袜a∨在线一区二区三区不卡| 国产日产高清欧美一区二区三区 | 日韩欧美一区二区三区免费看| 另类av一区二区| 色在线视频观看| 日韩精品亚洲aⅴ在线影院| 欧洲毛片在线视频免费观看| 日韩 欧美一区二区三区| 日韩中文在线电影| 日本a口亚洲| 久久精品国产www456c0m| 欧美亚洲三区| 国产一区成人| 天堂网av成人| 欧美aⅴ一区二区三区视频|