Java 數(shù)據(jù)庫連接(JDBC)的相關(guān)總結(jié)
Java 數(shù)據(jù)庫連接(Java DataBase Connectivity,縮寫JDBC)是官方(sun公司)定義的一套操作所有關(guān)系型數(shù)據(jù)庫的規(guī)則(即接口)。各個數(shù)據(jù)庫廠商去實(shí)現(xiàn)這套接口,提供數(shù)據(jù)庫驅(qū)動jar包。我們可以使用這套接口(JDBC)編程,真正執(zhí)行的代碼是驅(qū)動jar包中的實(shí)現(xiàn)類。
一、JDBC API 概述JDBC API主要位于JDK中的java.sql包中(之后擴(kuò)展的內(nèi)容位于javax.sql包中),主要包括(下面的接口,需驅(qū)動程序提供者來具體實(shí)現(xiàn)):
DriverManager:負(fù)責(zé)加載各種不同驅(qū)動程序(Driver),并根據(jù)不同的請求,向調(diào)用者返回相應(yīng)的數(shù)據(jù)庫連接(Connection)。 Driver:驅(qū)動程序,會將自身加載到DriverManager中去,并處理相應(yīng)的請求,返回相應(yīng)的數(shù)據(jù)庫連接(Connection)。 Connection:與數(shù)據(jù)庫連接,負(fù)責(zé)與進(jìn)行數(shù)據(jù)庫間通訊,SQL執(zhí)行、事務(wù)處理都是在某個特定Connection環(huán)境中進(jìn)行的。 Statement:用以執(zhí)行SQL查詢和更新(針對靜態(tài)SQL語句和單次執(zhí)行)。 PreparedStatement:用以執(zhí)行包含動態(tài)參數(shù)的SQL查詢和更新(在服務(wù)器端編譯,允許重復(fù)執(zhí)行以提高效率)。 CallableStatement:用以調(diào)用數(shù)據(jù)庫中的存儲過程。 SQLException:代表在數(shù)據(jù)庫連接的建立和關(guān)閉和SQL語句的執(zhí)行過程中發(fā)生了例外情況(即錯誤)。 二、JDBC 和 數(shù)據(jù)庫建立連接的過程2.1、裝載驅(qū)動程序Java 程序和數(shù)據(jù)庫建立連接,首先需要下載好對應(yīng)數(shù)據(jù)庫的驅(qū)動程序包,并放置在程序的依賴庫中。程序?qū)⒁蕾噹熘械尿?qū)動加載到程序中的方式非常簡單,使用Class.forName()即可。
假如需要導(dǎo)入的驅(qū)動包為 mysql-connector-java-5.1.37-bin.jar,則裝載驅(qū)動的方式:Class.forName('com.mysql.jdbc.Driver');在驅(qū)動程序的文檔中會告訴你應(yīng)該使用的類名。在裝載驅(qū)動的過程中,會執(zhí)行驅(qū)動程序中的部分代碼(靜態(tài)代碼塊);實(shí)現(xiàn)驅(qū)動與 DriverManager的綁定。
static { try { java.sql.DriverManager.registerDriver(new Driver()); } catch (SQLException E) { throw new RuntimeException('Can’t register driver!'); } }
注意:mysql5之后的驅(qū)動jar包可以省略注冊驅(qū)動(forName)的步驟。Jar包中內(nèi)置包含處理了此過程。
2.2、獲取數(shù)據(jù)庫連接下一步就是用適當(dāng)?shù)尿?qū)動程序類與 DBMS 建立一個連接。下列代碼是一般的做法:
Connection con = DriverManager.getConnection(url,user,password);
方法:static Connection getConnection(String url, String user, String password)說明:返回一個打開的連接,你可以使用此連接創(chuàng)建 JDBC statements 并發(fā)送 SQL 語句到數(shù)據(jù)庫。參數(shù): * url:指定連接的路徑;如:jdbc:mysql://localhost:3306/db3 * user:用戶名 * password:密碼
如果你裝載的驅(qū)動程序識別了提供給 DriverManager.getConnection 的 JDBC URL ,那個驅(qū)動程序?qū)⒏鶕?jù) JDBC URL 建立一個到指定 DBMS 的連接。正如名稱所示,DriverManager 類在幕后為你管理建立連接的所有細(xì)節(jié)。除非你是正在寫驅(qū)動程序,你可能無需使用此類的其它任何方法,一般程序員需要在此類中直接使用的唯一方法是 DriverManager.getConnection。
2.2.1、Connection:數(shù)據(jù)庫連接對象介紹Connection 對象與數(shù)據(jù)庫連接;負(fù)責(zé)與進(jìn)行數(shù)據(jù)庫間通訊,SQL執(zhí)行以及事務(wù)處理都是在某個特定Connection環(huán)境中進(jìn)行的。
產(chǎn)生用以執(zhí)行SQL指令的 Statement、PreparedStatement 對象。 事務(wù)管理中:setAutoCommit(boolean autoCommit)開啟事務(wù)、commit()提交事務(wù)、rollback()回滾事務(wù)。 2.3、創(chuàng)建 JDBC Statement 對象Statement 是執(zhí)行SQL 的對象;其用于把 SQL 語句發(fā)送到 DBMS。不同的SQL語句使用不同的 Statement 對象的方法,發(fā)送到 DBMS中。
Statement stmt = con.createStatement();2.4、執(zhí)行SQL 語句 (Statement對象方法使用)
不同的 SQL 語句需要使用不同的 Statement 對象方法。
boolean execute(String sql):可以執(zhí)行任意的sql(了解 )。 int executeUpdate(String sql):執(zhí)行DML(insert、update、delete)語句、DDL(create,alter、drop)語句。 ResultSet executeQuery(String sql):執(zhí)行DQL(select)語句其中 executeUpdate() 方法的返回值為影響的行數(shù);可以通過這個影響的行數(shù)判斷DML語句是否執(zhí)行成功 ;返回值>0的則執(zhí)行成功,反之,則失敗。
執(zhí)行DML語句
String sql = 'insert into account values(null,’王五’,3000)';int count = stmt.executeUpdate(sql);//影響的行數(shù)
執(zhí)行DQL語句
ResultSet rs = stmt.executeQuery('SELECT user_name, age FROM student');//如果有數(shù)據(jù),rs.next()返回truewhile(rs.next()){System.out.println(rs.getString('user_name')+' 年齡:'+rs.getInt('age'));}2.4.1、ResultSet 結(jié)果集對象,封裝查詢結(jié)果
java.sql.ResultSet 接口表示一個數(shù)據(jù)庫查詢的結(jié)果集;一個ResultSet對象具有一個游標(biāo)指向當(dāng)前行的結(jié)果集。最初,光標(biāo)被置于第一行之前;調(diào)用 next() 方法將光標(biāo)移動到下一行;當(dāng) ResultSet 對象沒有下一行時(shí),next() 方法返回 false。
一般使用方法:
while(rs.next()){ //獲取數(shù)據(jù) int id = rs.getInt(1); String name = rs.getString('name'); double balance = rs.getDouble(3); System.out.println(id + '---' + name + '---' + balance);}
getXxx(參數(shù)):獲取數(shù)據(jù) * Xxx:代表數(shù)據(jù)類型如:int getInt(),String getString() ... * 參數(shù): 1. int:代表列的編號,從1開始 如: getString(1) 2. String:代表列名稱。 如: getDouble('balance')
2.5、釋放資源SQL 語句執(zhí)行完成后,需要是否創(chuàng)建的資源對象。包括連接對象、Statement對象和ResultSet 對象等。
以上就是Java 數(shù)據(jù)庫連接(JDBC)的相關(guān)總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Java 數(shù)據(jù)庫連接(JDBC)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. 解決Android Studio 格式化 Format代碼快捷鍵問題2. php解決注冊并發(fā)問題并提高QPS3. JavaEE SpringMyBatis是什么? 它和Hibernate的區(qū)別及如何配置MyBatis4. Java使用Tesseract-Ocr識別數(shù)字5. Springboot 全局日期格式化處理的實(shí)現(xiàn)6. Python使用urlretrieve實(shí)現(xiàn)直接遠(yuǎn)程下載圖片的示例代碼7. SpringBoot+TestNG單元測試的實(shí)現(xiàn)8. JavaScript實(shí)現(xiàn)頁面動態(tài)驗(yàn)證碼的實(shí)現(xiàn)示例9. vue實(shí)現(xiàn)web在線聊天功能10. 完美解決vue 中多個echarts圖表自適應(yīng)的問題
