溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql基礎(chǔ)(六)mysql事務

發(fā)布時間:2020-07-14 19:01:04 來源:網(wǎng)絡 閱讀:371 作者:紅塵世間 欄目:數(shù)據(jù)庫
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è)置事務日志存放位置	


向AI問一下細節(jié)

免責聲明:本站發(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)容。

AI