ORM框架之基礎(chǔ)的JDBC

一辰企、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. 功能示意

JDBC功能

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)用流程

JDBC應(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

四拓售、JDBC總結(jié)


JDBC知識(shí)點(diǎn)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市镶奉,隨后出現(xiàn)的幾起案子础淤,更是在濱河造成了極大的恐慌崭放,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鸽凶,死亡現(xiàn)場(chǎng)離奇詭異币砂,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)玻侥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門决摧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人凑兰,你說我怎么就攤上這事掌桩。” “怎么了姑食?”我有些...
    開封第一講書人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵波岛,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我音半,道長(zhǎng)则拷,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任曹鸠,我火速辦了婚禮煌茬,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘彻桃。我一直安慰自己宣旱,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開白布叛薯。 她就那樣靜靜地躺著,像睡著了一般笙纤。 火紅的嫁衣襯著肌膚如雪耗溜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,829評(píng)論 1 290
  • 那天省容,我揣著相機(jī)與錄音抖拴,去河邊找鬼。 笑死腥椒,一個(gè)胖子當(dāng)著我的面吹牛阿宅,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播笼蛛,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼洒放,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了滨砍?” 一聲冷哼從身側(cè)響起往湿,我...
    開封第一講書人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤妖异,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后领追,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體他膳,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年绒窑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了棕孙。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡些膨,死狀恐怖蟀俊,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情傀蓉,我是刑警寧澤欧漱,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站葬燎,受9級(jí)特大地震影響误甚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜谱净,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一窑邦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧壕探,春花似錦冈钦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至导盅,卻和暖如春较幌,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背白翻。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工乍炉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人滤馍。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓岛琼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親巢株。 傳聞我的和親對(duì)象是個(gè)殘疾皇子槐瑞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容