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

您的位置:首頁技術文章
文章詳情頁

淺析JDBC的使用方法

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

1.使用步驟:

導包 加載驅動類class.forName(....) DriverManager獲取sql對象 寫sql語句 Statement與prepareStatement不一樣的執行sql語句,前者是直接sql對象 . 執行語句,而后者是預處理,即在創建sql對象時,就用sql語句,最后在用對象執行操作。

2.JDBCUtils工具類:

就是把使用步驟的共性,提出來,放在一個類中,這樣以后就能直接調用創建sql對象的方法就行了。

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

public class JDBCUtils { private static String url; private static String user; private static String password; private static String driver; /** * 文件的讀取,只需要讀取一次即可拿到這些值。使用靜態代碼塊 */ static{ //讀取資源文件,獲取值。 try { //1. 創建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. 獲取數據,賦值 url = pro.getProperty('url'); user = pro.getProperty('user'); password = pro.getProperty('password'); driver = pro.getProperty('driver'); //4. 注冊驅動 Class.forName(driver); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } } /** * 獲取連接 * @return 連接對象 */ 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控制事務

在執行sql語句時,如果程序執行過程中,發生了異常。比如有兩個sql語句,一個是轉賬操作,一個人存轉的這筆錢,如果第一個操作結束后發生了異常。那么這筆錢就會不翼而飛,所以為了避免這樣的情況,可以使用事務。

具體操作

開啟事務:setAutoCommit( boolean autoCommit ) :調用該方法設置參數為false,即開啟事務。 提交事務:commit( )當所有sql都執行完提交事務。 回滾事務:rollback( ) 在catch中回滾事務。

public static void main(String[] args) { PreparedStatement pstmt1 = null; PreparedStatement pstmt2 = null; Connection con = null; try { con = JDBCUtils.getConnection(); //開啟事務 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. 設置參數,sql語句里的問號 pstmt1.setDouble(1,500);//填第一個數據 pstmt1.setInt(2,1);//填第二個數據 pstmt2.setDouble(1,500); pstmt2.setInt(2,2); //5.執行sql pstmt1.executeUpdate(); // 手動制造異常 int i = 3/0; pstmt2.executeUpdate(); //提交事務 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連接池

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

c3p0連接池:

1.步驟:

導入jar包 (兩個) c3p0-0.9.5.2.jar mchange-commons-java-0.2.12.jar ,還需要導入數據庫驅動jar包

2.定義配置文件:

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

3.創建核心對象 數據庫連接池對象 ComboPooledDataSource

4.獲取連接: getConnection

代碼:

//1.創建數據庫連接池對象 DataSource ds = new ComboPooledDataSource(); //2. 獲取連接對象 Connection conn = ds.getConnection();

druid:

這個是阿里的,性能更好,效率更高。

1.步驟:

導入jar包 druid-1.0.9.jar

2.定義配置文件:

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

3.加載配置文件。Properties

4.獲取數據庫連接池對象:通過工廠類來獲取 DruidDataSourceFactory

5.獲取連接:getConnection

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

由于代碼還是冗長,重復率高,所以可以自定義個工具類:

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框架對JDBC的簡單封裝。提供了一個JDBCTemplate對象簡化JDBC的開發

1.步驟:

導入jar包創建JdbcTemplate對象。依賴于數據源DataSource

JdbcTemplate template = new JdbcTemplate(ds);

2.調用JdbcTemplate的方法來完成CRUD的操作

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

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

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

query的參數:RowMapper

一般我們使用BeanPropertyRowMapper實現類??梢酝瓿蓴祿絁avaBean的自動封裝new BeanPropertyRowMapper<類型>(類型.class)queryForObject:查詢結果,將結果封裝為對象

一般用于聚合函數的查詢

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

這大大簡化了我們curd的代碼量。

以上就是淺析JDBC的使用方法的詳細內容,更多關于Java jdbc使用的資料請關注好吧啦網其它相關文章!

標簽: JDBC
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩欧美中文在线观看| 亚洲一区av| 国产精品亚洲产品| 91麻豆精品激情在线观看最新 | 免费av一区二区三区四区| 欧美三级精品| 免费一级欧美片在线观看网站| 国产毛片精品| 久久av电影| 精品精品99| 国产精品久久久久久久免费观看| 日本免费一区二区三区四区| 日韩欧美一区二区三区在线观看 | 久久亚洲国产精品尤物| 欧美精品aa| 美女久久久久久| 波多视频一区| 亚洲黄页一区| 日本欧洲一区二区| 欧美日韩va| 精品美女久久| 久久精品卡一| 在线一区欧美| 日本不卡中文字幕| 久久精品理论片| 午夜av不卡| 91九色精品| 少妇精品久久久| 日韩高清一区在线| 国产九九精品| 欧美黄色网页| av不卡在线| 欧美视频久久| 成人国产精品| 国产亚洲永久域名| 日韩美女精品| 精品视频黄色| 日韩激情一二三区| 动漫av一区| 夜久久久久久| 欧美国产不卡| 合欧美一区二区三区| 日韩一区二区三免费高清在线观看 | 91欧美日韩| 尹人成人综合网| 欧美视频精品全部免费观看| 日韩成人亚洲| 日韩av不卡在线观看| 亚洲最新无码中文字幕久久| 蜜桃91丨九色丨蝌蚪91桃色| 美女精品久久| 好看的亚洲午夜视频在线| 国产精品中文字幕制服诱惑| 999国产精品| 欧美日韩中出| 久久中文字幕av一区二区不卡| 日韩av中文字幕一区二区| 成人啊v在线| 国产亚洲观看| 国产精品毛片在线看| 国产一区二区三区网| 蜜桃av一区二区| 日韩国产欧美| 欧美日韩xxxx| 中文久久精品| 国产精品毛片久久| 四虎精品永久免费| 欧美肉体xxxx裸体137大胆| 国产精品久久乐| 午夜在线视频观看日韩17c| 国内不卡的一区二区三区中文字幕| 久久国产精品毛片| 日韩一区电影| 国产精品99久久免费| 免费精品视频在线| 亚洲成人二区| 精品免费视频| 国产欧美综合一区二区三区| 国内精品福利| 国产suv精品一区| 日韩福利视频一区| 久久精品欧美一区| 精品国产一区二区三区av片| 综合欧美精品| 亚洲免费激情| 秋霞国产精品| 精品视频自拍| 国产精品啊啊啊| 日本亚洲视频在线| 国产视频一区三区| 日韩一区二区在线免费| 精品国产亚洲日本| 国产精品视频3p| 亚洲不卡视频| 一区二区三区网站| 国产视频一区三区| 青青久久av| 国产精品久久久久久久久妇女| 国产精品任我爽爆在线播放 | 国产aⅴ精品一区二区四区| 日韩精品中文字幕吗一区二区| 女人天堂亚洲aⅴ在线观看| 在线看片福利| 美女视频黄 久久| 国产精品2023| 国产精品一区二区三区av| 日韩va欧美va亚洲va久久| 亚洲精品护士| 午夜在线精品| 狠狠爱成人网| 欧美网站在线| 红桃视频欧美| 在线亚洲自拍| 美日韩精品视频| 日韩天堂av| 国产精品女主播一区二区三区| 婷婷成人基地| 亚洲精品一区二区在线看| 伊人精品一区| 亚洲婷婷在线| 在线日韩中文| 亚洲激情久久| 久久国产精品亚洲77777| 91精品高清| 9色精品在线| 日韩在线播放一区二区| 日韩一区精品视频| 影音先锋久久精品| 五月亚洲婷婷 | 欧美日韩午夜电影网| 国产精品美女午夜爽爽| 国产精品视频一区二区三区| 欧美精品不卡| 97视频热人人精品免费| 成人国产精品久久| 99久久久久久中文字幕一区| 免费视频亚洲| 视频一区中文字幕国产| 日韩精品视频中文字幕| 久久精品99国产精品| 国产精品大片免费观看| 久久久久久婷| 九一成人免费视频| 中文一区一区三区免费在线观 | 国产成人精品一区二区三区免费| 涩涩av在线| 久久一区二区中文字幕| 日韩中文字幕一区二区三区| 欧美另类中文字幕 | 亚洲午夜视频| 免费在线观看成人| 欧美私人啪啪vps| 久久精品国产网站| 欧美日韩在线播放视频| 伊人久久大香伊蕉在人线观看热v| 欧美日韩一区二区高清| 精品视频91| 久久香蕉国产| 亚洲精品在线国产| 久久精品国产久精国产爱| 欧美成人基地| 亚洲va久久| www在线观看黄色| 国产农村妇女精品一区二区 | 亚洲另类黄色| 精品国产不卡| 91tv亚洲精品香蕉国产一区| 老司机精品久久| 国产精品亚洲欧美| 亚洲精品.com| 日韩精品免费视频一区二区三区| 免费看久久久| 亚洲综合精品四区| 欧美激情视频一区二区三区在线播放| 欧美二三四区| 97久久中文字幕| 秋霞国产精品| 国产日韩欧美一区二区三区在线观看| 日韩精品电影| 天海翼精品一区二区三区| аⅴ资源天堂资源库在线| 好吊日精品视频| 国产精品国码视频| 黄色日韩精品| 久久不卡日韩美女| 不卡在线一区二区| 国产精品4hu.www| 视频一区二区三区中文字幕| 国产精品www.| 亚洲深夜影院| 国产高清不卡| 欧美日韩一区二区国产| 136国产福利精品导航网址| 国产日本精品| 午夜一区在线| 神马午夜在线视频| 欧美久久久网站| 自由日本语亚洲人高潮| 成人黄色av| 欧美亚洲三级|