一辰企、JDBC說明
1. 概念說明
JDBC(Java DataBase Connectivity,java數(shù)據(jù)庫連接)是一種用于執(zhí)行SQL語句的Java API捅暴,可以為多種關(guān)系數(shù)據(jù)庫提供統(tǒng)一訪問膳凝,它由一組用Java語言編寫的類和接口組成因俐。
JDBC提供了一種基準(zhǔn)抬驴,據(jù)此可以構(gòu)建更高級(jí)的工具和接口秒啦,使數(shù)據(jù)庫開發(fā)人員能夠編寫數(shù)據(jù)庫應(yīng)用程序领曼。
JDBC 可做三件事:與數(shù)據(jù)庫建立連接鸥鹉、發(fā)送 操作數(shù)據(jù)庫的語句并處理結(jié)果。
直接調(diào)用 SQL 命令庶骄。在這方面它的功能極佳毁渗,并比其它的數(shù)據(jù)庫連接 API 易于使用,但它同時(shí)也被設(shè)計(jì)為一種基礎(chǔ)接口单刁,在它之上可以建立高級(jí)接口和工具灸异。
在關(guān)系數(shù)據(jù)庫的"對(duì)象/關(guān)系"3映射中,表中的每行對(duì)應(yīng)于類的一個(gè)實(shí)例,而每列的值對(duì)應(yīng)于該實(shí)例的一個(gè)屬性肺樟。
2. 功能示意
3. 常用接口
3.1 Driver接口
由數(shù)據(jù)庫廠家提供檐春,作為java開發(fā)人員,只需要使用Driver接口就可以了么伯。在編程中要連接數(shù)據(jù)庫疟暖,必須先裝載特定廠商的數(shù)據(jù)庫驅(qū)動(dòng)程序,不同的數(shù)據(jù)庫有不同的裝載方法田柔。
3.2 Connection接口
Connection與特定數(shù)據(jù)庫的連接(會(huì)話)俐巴,在連接上下文中執(zhí)行sql語句并返回結(jié)果。DriverManager.getConnection(url, user, password)方法建立在JDBC URL中定義的數(shù)據(jù)庫Connection連接上硬爆。
3.3 Statement接口
用于執(zhí)行靜態(tài)SQL語句并返回它所生成結(jié)果的對(duì)象欣舵。在JDBC中Statement有三種類型:
(1)Statement:由createStatement創(chuàng)建,用于發(fā)送簡(jiǎn)單的SQL語句(不帶參數(shù))缀磕。
(2)PreparedStatement :繼承自Statement接口邻遏,由preparedStatement創(chuàng)建,用于發(fā)送含有一個(gè)或多個(gè)參數(shù)的SQL語句虐骑。PreparedStatement對(duì)象比Statement對(duì)象的效率更高,并且可以防止SQL注入赎线,所以我們一般都使用PreparedStatement廷没。
(3)CallableStatement:繼承自PreparedStatement接口,由方法prepareCall創(chuàng)建垂寥,用于調(diào)用存儲(chǔ)過程颠黎。
常用Statement方法:
(1)execute(String sql):運(yùn)行語句,返回是否有結(jié)果集
(2)executeQuery(String sql):運(yùn)行select語句滞项,返回ResultSet結(jié)果集狭归。
(3)executeUpdate(String sql):運(yùn)行insert/update/delete操作,返回更新的行數(shù)文判。
(4)addBatch(String sql) :把多條sql語句放到一個(gè)批處理中过椎。
(5)executeBatch():向數(shù)據(jù)庫發(fā)送一批sql語句執(zhí)行。
3.4 ResultSet接口
1. 提供檢索不同類型字段的方法戏仓,具體如下:
(1)getString(int index)疚宇、getString(String columnName):獲得在數(shù)據(jù)庫里是varchar、char等類型的數(shù)據(jù)對(duì)象赏殃。
(2)getFloat(int index)敷待、getFloat(String columnName):獲得在數(shù)據(jù)庫里是Float類型的數(shù)據(jù)對(duì)象。
(3)getDate(int index)仁热、getDate(String columnName):獲得在數(shù)據(jù)庫里是Date類型的數(shù)據(jù)榜揖。
(4)getBoolean(int index)、getBoolean(String columnName):獲得在數(shù)據(jù)庫里是Boolean類型的數(shù)據(jù)。
(5)getObject(int index)举哟、getObject(String columnName):獲取在數(shù)據(jù)庫里任意類型的數(shù)據(jù)思劳。
2. 提供了對(duì)結(jié)果集進(jìn)行滾動(dòng)的方法
(1)next():移動(dòng)到下一行
(2)Previous():移動(dòng)到前一行
(4)absolute(int row):移動(dòng)到指定行
(5)beforeFirst():移動(dòng)resultSet的最前面。
(6)afterLast() :移動(dòng)到resultSet的最后面炎滞。
二敢艰、JDBC應(yīng)用
1. 應(yīng)用流程
2. 數(shù)據(jù)查詢
由Statement接口或其子類調(diào)用 executeQuery(String sql):運(yùn)行select語句,返回ResultSet結(jié)果集册赛,然后循環(huán)讀取結(jié)果集的中數(shù)據(jù)就完成了钠导。
3. 數(shù)據(jù)更新
由Statement接口或其子類調(diào)用 executeUpdate(String sql) 運(yùn)行SQL語句并返回最終的受影響行數(shù)就可以了。
4. 事務(wù)處理
4.1 事務(wù)定義
一組同時(shí)執(zhí)行的SQL語句森瘪,同時(shí)成功或失敗牡属,數(shù)據(jù)庫操作的一個(gè)基本單元。
4.2 事務(wù)特點(diǎn)(ACID)
(1)原子性(atomicity)扼睬,事務(wù)內(nèi)的所有操作是一個(gè)整體逮栅,要么同時(shí)成功要么同時(shí)失敗窗宇;
(2)一致性(consistency)措伐,事務(wù)內(nèi)一個(gè)操作失敗后,所有事務(wù)內(nèi)的修改成功后的數(shù)據(jù)都必須會(huì)滾到之前的狀態(tài)军俊;
(3)隔離性(isolation)侥加,事務(wù)查看數(shù)據(jù)時(shí)所處的狀態(tài)要么被另一個(gè)事務(wù)修改它之前的狀態(tài)要么是修改它之后的狀態(tài),事務(wù)不會(huì)查看中間狀態(tài)的數(shù)據(jù)粪躬,事務(wù)隔離級(jí)別從低到高(讀取未提交 ----- >? 讀取已提交 ----> 可重復(fù)讀 ---- > 序列化)担败;
(4)持久性(durability),持久性事務(wù)完成之后它對(duì)系統(tǒng)的影響是永久性的镰官;
4.3 代碼實(shí)現(xiàn)
只需要在創(chuàng)建數(shù)據(jù)鏈接對(duì)象Connection 對(duì)象之后設(shè)置 conn.setAutoCommit(false) 手動(dòng)提交事務(wù)就可以了提前,這樣每次更新之后的數(shù)據(jù)都需要進(jìn)行 conn.commit() 操作就可以保證數(shù)據(jù)的完整處理了。
5. 批量處理
單次更新數(shù)據(jù)需要重復(fù)的打開關(guān)閉一系列的數(shù)據(jù)對(duì)象泳唠,造成不必要的功能操作狈网,這樣影響性能,所以在實(shí)際開發(fā)中爭(zhēng)對(duì)那些可以進(jìn)行批量操作的數(shù)據(jù)可以提升數(shù)據(jù)處理速度警检。
6. 時(shí)間類型
Java中操作時(shí)間的包是java.util.Date孙援,我們?cè)贘DBC中可以選用的時(shí)間類型還可以是它的子類,具體如下:
(1)子類:java.sql.Date
(2)子類:java.sql.Time
(3)子類:java.sql.Timestamp
三扇雕、補(bǔ)充說明
1. 操作MySQL
(1) 鏈接URL? jdbc:mysql://數(shù)據(jù)庫服務(wù)器IP:數(shù)據(jù)庫端口/數(shù)據(jù)庫名稱
(2) 驅(qū)動(dòng)類? com.mysql.jdbc.Driver
2. 操作Oracle
(1) 鏈接URL? jdbc:oracle:thin:@數(shù)據(jù)庫服務(wù)器IP:數(shù)據(jù)庫端口:數(shù)據(jù)庫名稱
(2) 驅(qū)動(dòng)類 Oracle.jdbc.driver.OracleDriver
3. 操作DB2
3.1 驅(qū)動(dòng)包 db2java.zip
(1) 鏈接URL? jdbc:db2://數(shù)據(jù)庫服務(wù)器IP:數(shù)據(jù)庫端口/數(shù)據(jù)庫名稱
(2) 驅(qū)動(dòng)類? COM.ibm.db2.jdbc.net.DB2Driver
3.2 驅(qū)動(dòng)包 db2jcc.jar
(1) 鏈接URL? jdbc:db2://數(shù)據(jù)庫服務(wù)器IP:數(shù)據(jù)庫端口/數(shù)據(jù)庫名稱
(2) 驅(qū)動(dòng)類? com.ibm.db2.jcc.DB2Driver
4. 操作MSSQL
(1) 鏈接URL? jdbc:sqlserver://數(shù)據(jù)庫服務(wù)器IP:數(shù)據(jù)庫端口;DatabaseName=數(shù)據(jù)庫名稱
(2) 驅(qū)動(dòng)類? com.microsoft.sqlserver.jdbc.SQLServerDriver