欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

MySQLInnoDB事務(wù)-創(chuàng)新互聯(lián)

事務(wù)的定義

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站制作、做網(wǎng)站、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出大英免費(fèi)做網(wǎng)站回饋大家。

事務(wù):數(shù)據(jù)庫(kù)操作的最小工作單元,是作為單個(gè)邏輯工作單元執(zhí)行的一系列操作; 事務(wù)是一組不可再分割的操作集合(工作邏輯單元)。

典型事務(wù)使用場(chǎng)景:轉(zhuǎn)賬

MySQL InnoDB 事務(wù)
MySQL 開啟事務(wù):

MySQL InnoDB 事務(wù)
MySQL 默認(rèn)是開啟事務(wù)的,通過 SHOW VARIABLES like 'autocommit'; 可以查看 MySQL 的事務(wù)開啟情況。

在 autocommit = ON(自動(dòng)提交事務(wù))的情況下,可以執(zhí)行 BEGIN; 或者 START TRANSACTION; 命令,改為手動(dòng)提交事務(wù),執(zhí)行完 SQL 語句后,需要通過 COMMIT 命令提交事務(wù),或者通過 ROLLBACK 命令回滾事務(wù)。
在 autocommit = OFF(手動(dòng)提交事務(wù))的情況下,執(zhí)行完 SQL 語句后,需要通過 COMMIT 命令提交事務(wù),或者通過 ROLLBACK命令回滾事務(wù)。
JDBC 編程:

MySQL InnoDB 事務(wù)
測(cè)試命令:

MySQL InnoDB 事務(wù)
事務(wù) ACID 特性

原子性(Atomicity):最小的工作單元,整個(gè)工作單元要么一起提交成功,要么全部失敗回滾。

一致性(Consistency):事務(wù)中操作的數(shù)據(jù)及狀態(tài)改變是一致的,即寫入資料的結(jié)果必須完全符合預(yù)設(shè)的規(guī)則,不會(huì)因?yàn)槌霈F(xiàn)系統(tǒng)意外等原因?qū)е聽顟B(tài)的不一致。

隔離型(Isolation):一個(gè)事務(wù)所操作的數(shù)據(jù)在提交之前,對(duì)其他事務(wù)的可見性設(shè)定(一般設(shè)定為不可見)。

持久性(Durability):事務(wù)所做的修改就會(huì)永久保存,不會(huì)因?yàn)橄到y(tǒng)意外導(dǎo)致數(shù)據(jù)的丟失。

參考(原子性和一致性的區(qū)別是什么?)這篇博文,講了一下原子性和一致性的區(qū)別。

事務(wù)并發(fā)帶來了哪些問題

臟讀

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
比如 user 表中有一條用戶數(shù)據(jù),執(zhí)行了如下操作:

事務(wù)B更新 id=1 的數(shù)據(jù),age 更新為18,不提交事務(wù)
事務(wù)A查詢 id=1 的數(shù)據(jù)
事務(wù)B回滾剛才的更新操作
這個(gè)時(shí)候,事務(wù)A中查詢出的 id=1 的數(shù)據(jù),age 的值是16還是18?

不可重復(fù)讀

MySQL InnoDB 事務(wù)
比如 user 表中有一條用戶數(shù)據(jù),執(zhí)行了如下操作:

事務(wù)A查詢 id=1 的數(shù)據(jù)
事務(wù)B更新 id=1 的數(shù)據(jù),age 更新為18,并提交事務(wù)
事務(wù)A再次查詢 id=1 的數(shù)據(jù)
這個(gè)時(shí)候,事務(wù)A兩次查詢出的 id=1 的數(shù)據(jù),age 的值是16還是18?

幻讀

MySQL InnoDB 事務(wù)
比如在 user 表中執(zhí)行了如下操作:

事務(wù)A查詢 age>15 的數(shù)據(jù)
事務(wù)B新增一條數(shù)據(jù),age=22,并提交事務(wù)
事務(wù)A再次查詢 age>15 的數(shù)據(jù)
這個(gè)時(shí)候,事務(wù)A兩次查詢出的數(shù)據(jù),數(shù)量是1條還是2條?

事務(wù)四種隔離級(jí)別

SQL92 ANSI/ISO標(biāo)準(zhǔn):http://www.contrib.andrew.cmu.edu/~shadow/sql/sql1992.txt

Read Uncommitted(未提交讀) --未解決并發(fā)問題

事務(wù)未提交對(duì)其他事務(wù)也是可見的,臟讀(dirty read)

Read Committed(提交讀) --解決臟讀問題

一個(gè)事務(wù)開始之后,只能看到自己提交的事務(wù)所做的修改,不可重復(fù)讀(non repeatable read)

Repeatable Read(可重復(fù)讀) --解決不可重復(fù)讀問題

在同一個(gè)事務(wù)中多次讀取同樣的數(shù)據(jù)結(jié)果是一樣的,這種隔離級(jí)別未定義解決幻讀的問題

Serializable(串行化) --解決所有問題

高的隔離級(jí)別,通過強(qiáng)制事務(wù)的串行執(zhí)行

InnoDB 引擎對(duì)隔離級(jí)別的支持程度

MySQL InnoDB 事務(wù)
事務(wù)隔離級(jí)別的并發(fā)能力:未提交讀 > 已提交讀 > 可重復(fù)讀 > 串行化

InnDB 引擎默認(rèn)的事務(wù)隔離級(jí)別是可重復(fù)讀(Repeatable Read),在該級(jí)別中它把幻讀的問題也解決了。InnDB 中事務(wù)隔離級(jí)別通過鎖、MVCC 實(shí)現(xiàn)。

通過如下語句查看 InnoDB 的默認(rèn)事務(wù)隔離級(jí)別:

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
通過如下語句設(shè)置 InnoDB 的事務(wù)隔離級(jí)別:

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
接下來我們來測(cè)試一下 InnoDB 的默認(rèn)事務(wù)隔離級(jí)別(Repeatable Read)是否解決了臟讀、不可重復(fù)讀、幻讀的問題。

數(shù)據(jù)準(zhǔn)備:

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
是否解決了臟讀的問題?

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
開啟兩個(gè) MySQL 客戶端,模擬事務(wù)A和事務(wù)B的操作,執(zhí)行步驟如下:

事務(wù)B開啟手動(dòng)事務(wù),更新 id=1 的數(shù)據(jù),age 更新為18,不提交事務(wù)
事務(wù)A查詢 id=1 的數(shù)據(jù)
事務(wù)B回滾剛才的更新操作
圖中的數(shù)字是執(zhí)行步驟,通過下圖可以看出事務(wù)A的執(zhí)行結(jié)果是16,InnDB 的默認(rèn)事務(wù)隔離級(jí)別完美的解決了臟讀的問題。

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
是否解決了不可重復(fù)讀的問題?

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
開啟兩個(gè) MySQL 客戶端,模擬事務(wù)A和事務(wù)B的操作,執(zhí)行步驟如下:

事務(wù)A開啟手動(dòng)事務(wù),查詢 id=1 的數(shù)據(jù)
事務(wù)B更新 id=1 的數(shù)據(jù),age 更新為18,并提交事務(wù)
事務(wù)A再次查詢 id=1 的數(shù)據(jù)
圖中的數(shù)字是執(zhí)行步驟,通過下圖可以看出事務(wù)A兩次的執(zhí)行結(jié)果都是16,沒有受事務(wù)B更新操作的影響,InnDB 的默認(rèn)事務(wù)隔離級(jí)別完美的解決了不可重復(fù)讀的問題。

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
是否解決了幻讀的問題?

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)
開啟兩個(gè) MySQL 客戶端,模擬事務(wù)A和事務(wù)B的操作,執(zhí)行步驟如下:

事務(wù)A開啟手動(dòng)事務(wù),查詢 age>15 的數(shù)據(jù)
事務(wù)B新增一條數(shù)據(jù),age=22,并提交事務(wù)
事務(wù)A再次查詢 age>15 的數(shù)據(jù)
圖中的數(shù)字是執(zhí)行步驟,通過下圖可以看出事務(wù)A兩次的執(zhí)行結(jié)果都是一條數(shù)據(jù),沒有受事務(wù)B新增操作的影響,InnDB 的默認(rèn)事務(wù)隔離級(jí)別完美的解決了幻讀的問題。

MySQL InnoDB 事務(wù)MySQL InnoDB 事務(wù)

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)站標(biāo)題:MySQLInnoDB事務(wù)-創(chuàng)新互聯(lián)
URL地址:http://chinadenli.net/article36/diiopg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)網(wǎng)站策劃搜索引擎優(yōu)化網(wǎng)站改版網(wǎng)站設(shè)計(jì)公司品牌網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)