mysql事務(wù):是一個獨(dú)立的工作單元
事務(wù)必須通過ACID測試:
原子性(Atomicity):一個事務(wù)的所有操作要么全部成功執(zhí)行,要么全部失敗后回滾
一致性(Consistency):數(shù)據(jù)庫總是從一個一致性狀態(tài)轉(zhuǎn)換成另一個狀態(tài)
隔離性(Isolation):一個事務(wù)在做出的操作在提交之前,其他事務(wù)是不可見的,隔離有多種級別
持久性(Durability):一旦事務(wù)提交,其所做出的操作將永久保存在數(shù)據(jù)庫中
事務(wù)的執(zhí)行流程:
啟動事務(wù)-->執(zhí)行SQL語句-->提交事務(wù)-->保存數(shù)據(jù)
啟動事務(wù)-->執(zhí)行SQL語句-->回滾-->數(shù)據(jù)不發(fā)生任何改變
事務(wù)的隔離級別:
Read Uncommitted(讀取未提交內(nèi)容)
出現(xiàn)問題:1、2、3 #不建議使用此隔離級別
Read Committed(讀提交)
出現(xiàn)問題:2、3 #大多數(shù)數(shù)據(jù)庫使用的隔離級別,性能較好
Repeatable Read(不可重復(fù)讀)
出現(xiàn)問題:3 #mysql默認(rèn)使用的隔離級別
Serializable(串行化) #數(shù)據(jù)安全性最好,并發(fā)訪問能力最弱,可能會出現(xiàn)死鎖,
出現(xiàn)問題:4 除非在數(shù)據(jù)要求比較嚴(yán)格的情況下,否則不建議使用
出現(xiàn)問題:
1、臟讀:可以讀取其他事務(wù)沒有提交的數(shù)據(jù)
2、不可重復(fù)讀:在當(dāng)前事務(wù)中沒有做出任何修改,但使用select查看數(shù)據(jù)時可能查看到不同的數(shù)
3、幻讀:在當(dāng)前事務(wù)提交之前只能看見啟動事務(wù)時的數(shù)據(jù)和在當(dāng)前事務(wù)中做出修改的數(shù)據(jù),
而其他事務(wù)所做出的修改將不能看見
4、加鎖讀:如果在此事務(wù)中對表進(jìn)行修改,那么數(shù)據(jù)庫將給做出修改的表加上表鎖,
在此事務(wù)提交之前其他事務(wù)對此表做出的操作都會阻塞
mysql> SHOW VARIABLES LIKE '%iso%'; #查看當(dāng)前的隔離級別
SET tx_isolation='參數(shù)' #修改隔離級別
對應(yīng)參數(shù)(不區(qū)分大小寫):
Read-Uncommitted #1
Read-Committed #2
Repeatable-Read #3(默認(rèn))
Serializable #4
mysql> SET GLOBAL autocommit=0; #關(guān)閉自動提交事務(wù)
mysql> START TRANSACTION #啟動事務(wù)
mysql> COMMIT #提交事務(wù)
mysql> ROLLBACK #回滾
mysql事務(wù)日志:
同事務(wù)日志和崩潰后安全恢復(fù)可以很好的保存數(shù)據(jù)安全
事務(wù)日志包括:重做日志redo和回滾日志undo,事務(wù)日志通常比較小
Redo記錄的是已經(jīng)全部完成的事務(wù),就是執(zhí)行了COMMIT的事務(wù)
記錄日志組是ib_logfile0、ib_logfile1 記錄日志組可以更加需要調(diào)整文件數(shù)量
Undo記錄的是已部分完成并且寫入硬盤的未完成的事務(wù)
在mysq重啟后,innodb通過事務(wù)日志將所有已完成并寫入磁盤的和未完成的事務(wù)進(jìn)行同步
并將數(shù)據(jù)寫入到磁盤中完成數(shù)據(jù)庫崩潰后安全恢復(fù)
mysql> SHOW VARIABLES LIKE 'innodb_log%'; #查看事務(wù)日志的相關(guān)配置
innodb_log_file_size #設(shè)置事務(wù)日志大小
innodb_log_files_in_group #設(shè)置事務(wù)日志組文件數(shù)量
innodb_log_group_home_dir #設(shè)置事務(wù)日志存放位置
成都創(chuàng)新互聯(lián)專注于清遠(yuǎn)網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供清遠(yuǎn)營銷型網(wǎng)站建設(shè),清遠(yuǎn)網(wǎng)站制作、清遠(yuǎn)網(wǎng)頁設(shè)計(jì)、清遠(yuǎn)網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造清遠(yuǎn)網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供
清遠(yuǎn)網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
本文標(biāo)題:mysql基礎(chǔ)(六)mysql事務(wù)-創(chuàng)新互聯(lián)
標(biāo)題網(wǎng)址:
http://weahome.cn/article/dscdgp.html