您好,登錄后才能下訂單哦!
mysql事務:是一個獨立的工作單元 事務必須通過ACID測試: 原子性(Atomicity):一個事務的所有操作要么全部成功執(zhí)行,要么全部失敗后回滾 一致性(Consistency):數(shù)據(jù)庫總是從一個一致性狀態(tài)轉(zhuǎn)換成另一個狀態(tài) 隔離性(Isolation):一個事務在做出的操作在提交之前,其他事務是不可見的,隔離有多種級別 持久性(Durability):一旦事務提交,其所做出的操作將永久保存在數(shù)據(jù)庫中 事務的執(zhí)行流程: 啟動事務-->執(zhí)行SQL語句-->提交事務-->保存數(shù)據(jù) 啟動事務-->執(zhí)行SQL語句-->回滾-->數(shù)據(jù)不發(fā)生任何改變 事務的隔離級別: Read Uncommitted(讀取未提交內(nèi)容) 出現(xiàn)問題:1、2、3 #不建議使用此隔離級別 Read Committed(讀提交) 出現(xiàn)問題:2、3 #大多數(shù)數(shù)據(jù)庫使用的隔離級別,性能較好 Repeatable Read(不可重復讀) 出現(xiàn)問題:3 #mysql默認使用的隔離級別 Serializable(串行化) #數(shù)據(jù)安全性最好,并發(fā)訪問能力最弱,可能會出現(xiàn)死鎖, 出現(xiàn)問題:4 除非在數(shù)據(jù)要求比較嚴格的情況下,否則不建議使用 出現(xiàn)問題: 1、臟讀:可以讀取其他事務沒有提交的數(shù)據(jù) 2、不可重復讀:在當前事務中沒有做出任何修改,但使用select查看數(shù)據(jù)時可能查看到不同的數(shù) 3、幻讀:在當前事務提交之前只能看見啟動事務時的數(shù)據(jù)和在當前事務中做出修改的數(shù)據(jù), 而其他事務所做出的修改將不能看見 4、加鎖讀:如果在此事務中對表進行修改,那么數(shù)據(jù)庫將給做出修改的表加上表鎖, 在此事務提交之前其他事務對此表做出的操作都會阻塞 mysql> SHOW VARIABLES LIKE '%iso%'; #查看當前的隔離級別 SET tx_isolation='參數(shù)' #修改隔離級別 對應參數(shù)(不區(qū)分大小寫): Read-Uncommitted #1 Read-Committed #2 Repeatable-Read #3(默認) Serializable #4 mysql> SET GLOBAL autocommit=0; #關(guān)閉自動提交事務 mysql> START TRANSACTION #啟動事務 mysql> COMMIT #提交事務 mysql> ROLLBACK #回滾 mysql事務日志: 同事務日志和崩潰后安全恢復可以很好的保存數(shù)據(jù)安全 事務日志包括:重做日志redo和回滾日志undo,事務日志通常比較小 Redo記錄的是已經(jīng)全部完成的事務,就是執(zhí)行了COMMIT的事務 記錄日志組是ib_logfile0、ib_logfile1 記錄日志組可以更加需要調(diào)整文件數(shù)量 Undo記錄的是已部分完成并且寫入硬盤的未完成的事務 在mysq重啟后,innodb通過事務日志將所有已完成并寫入磁盤的和未完成的事務進行同步 并將數(shù)據(jù)寫入到磁盤中完成數(shù)據(jù)庫崩潰后安全恢復 mysql> SHOW VARIABLES LIKE 'innodb_log%'; #查看事務日志的相關(guān)配置 innodb_log_file_size #設(shè)置事務日志大小 innodb_log_files_in_group #設(shè)置事務日志組文件數(shù)量 innodb_log_group_home_dir #設(shè)置事務日志存放位置
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。