淺析JDBC的使用方法
1.使用步驟:
- 導(dǎo)包
- 加載驅(qū)動(dòng)類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),放在一個(gè)類中,這樣以后就能直接調(diào)用創(chuàng)建sql對(duì)象的方法就行了。
值得一提的是,如果我們使用配置文件,擴(kuò)展性更好,在使用其他數(shù)據(jù)庫(kù)時(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語(yǔ)句時(shí),如果程序執(zhí)行過(guò)程中,發(fā)生了異常。比如有兩個(gè)sql語(yǔ)句,一個(gè)是轉(zhuǎn)賬操作,一個(gè)人存轉(zhuǎn)的這筆錢,如果第一個(gè)操作結(jié)束后發(fā)生了異常。那么這筆錢就會(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.定義配置文件:
名稱: 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形式的
可以叫任意名稱,可以放在任意目錄下
3.加載配置文件。Properties
4.獲取數(shù)據(jù)庫(kù)連接池對(duì)象:通過(guò)工廠類來(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è)工具類:
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ì)象。依賴于數(shù)據(jù)源DataSource
JdbcTemplate template = new JdbcTemplate(ds);
2.調(diào)用JdbcTemplate的方法來(lái)完成CRUD的操作
update():執(zhí)行DML語(yǔ)句。增、刪、改語(yǔ)句
queryForMap():查詢結(jié)果將結(jié)果集封裝為map集合,將列名作為key,將值作為value 將這條記錄封裝為一個(gè)map集合
注意:這個(gè)方法查詢的結(jié)果集長(zhǎng)度只能是1
queryForList():查詢結(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í)行sql int count = template.update(sql); System.out.println(count);
這大大簡(jiǎn)化了我們curd的代碼量。
以上就是淺析JDBC的使用方法的詳細(xì)內(nèi)容,更多關(guān)于Java jdbc使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Java JDBC基本使用方法詳解
- java數(shù)據(jù)庫(kù)開(kāi)發(fā)之JDBC基礎(chǔ)使用方法及實(shí)例詳解
- Java使用Jdbc連接Oracle執(zhí)行簡(jiǎn)單查詢操作示例
- Java使用JDBC連接postgresql數(shù)據(jù)庫(kù)示例
- java使用jdbc連接數(shù)據(jù)庫(kù)簡(jiǎn)單實(shí)例
- Java使用jdbc連接MySQL數(shù)據(jù)庫(kù)實(shí)例分析
- JDBC中使用Java8的日期LocalDate和LocalDateTime操作mysql、postgresql
- java使用JDBC動(dòng)態(tài)創(chuàng)建數(shù)據(jù)表及SQL預(yù)處理的方法
- Java 使用JdbcTemplate 中的queryForList發(fā)生錯(cuò)誤解決辦法
- Java使用JDBC驅(qū)動(dòng)連接MySQL數(shù)據(jù)庫(kù)
相關(guān)文章
java中的靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造方法詳解
下面小編就為大家?guī)?lái)一篇java中的靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造方法詳解。小編覺(jué)得挺好的,現(xiàn)在分享給大家。給大家一個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-03-03Java實(shí)現(xiàn)生成Excel樹(shù)形表頭完整代碼示例
這篇文章主要介紹了Java實(shí)現(xiàn)生成Excel樹(shù)形表頭完整代碼示例,具有一定借鑒價(jià)值,需要的朋友可以參考下。2017-12-12Java實(shí)現(xiàn)n位數(shù)字的全排列
今天小編就為大家分享一篇關(guān)于Java實(shí)現(xiàn)n位數(shù)字的全排列,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02詳解hashCode()和equals()的本質(zhì)區(qū)別和聯(lián)系
這篇文章主要介紹了詳解hashCode()和equals()的本質(zhì)區(qū)別和聯(lián)系,本文先對(duì)兩種方法作了介紹,然后對(duì)二者聯(lián)系進(jìn)行分析,具有一定參考價(jià)值,需要的朋友可以了解下。2017-09-09java正則表達(dá)式表單驗(yàn)證類工具類(驗(yàn)證郵箱、手機(jī)號(hào)碼、qq號(hào)碼等)
這篇文章主要介紹了java使用正則表達(dá)式進(jìn)行表單驗(yàn)證工具類,可以驗(yàn)證郵箱、手機(jī)號(hào)碼、qq號(hào)碼等方法,需要的朋友可以參考下2014-04-04