mysql事務(wù)對(duì)效率的影響分析總結(jié)
1、數(shù)據(jù)庫事務(wù)會(huì)降低數(shù)據(jù)庫的性能。為了保證數(shù)據(jù)的一致性和隔離性,事務(wù)需要鎖定事務(wù)。
2、如果其他事務(wù)需要操作這部分?jǐn)?shù)據(jù),必須等待最后一個(gè)事務(wù)結(jié)束(提交,回滾)。
實(shí)例
create table acct( acct_no varchar(32), acct_name varchar(32), balance decimal(16,2) ); insert into acct values ('0001','Jerry', 1000), ('0002','Tom', 2000); start transaction; -- 啟動(dòng)事務(wù) update acct set balance = balance - 100 where acct_no = '0001'; -- 模擬扣款人 update acct set balance = balance + 100 where acct_no = '0002'; -- 模擬收款人 commit; -- 事務(wù)提交 rollback; -- 事務(wù)回滾
知識(shí)點(diǎn)擴(kuò)展:
事務(wù)
- 原子性:整個(gè)事務(wù)的所有操作要么全部提交成功,要么全部失敗回滾
- 一致性:指事務(wù)將數(shù)據(jù)庫從一種一致性狀態(tài)轉(zhuǎn)換到另外一種一致性狀態(tài),在事務(wù)開始之前和事務(wù)結(jié)束后數(shù)據(jù)庫中的完整性沒有被破壞
- 隔離性:要求一個(gè)事務(wù)對(duì)數(shù)據(jù)庫中數(shù)據(jù)修改,在未提交完成前對(duì)其他事務(wù)是不可見的
- 持久性:一旦事務(wù)提交,則其所做的修改就會(huì)永久保存到數(shù)據(jù)庫中。此時(shí)即使系統(tǒng)崩潰,已經(jīng)提交的修改數(shù)據(jù)也不會(huì)丟失。
大事務(wù)
運(yùn)行時(shí)間比較長(zhǎng),操作的數(shù)據(jù)比較多的事務(wù)
- 鎖定太多的數(shù)據(jù),造成大量的阻塞和鎖超時(shí)
- 回滾時(shí)所需時(shí)間比較長(zhǎng)
- 執(zhí)行時(shí)間長(zhǎng),容易造成主從延遲
如何處理大事務(wù):
- 避免一次處理太多的數(shù)據(jù)
- 移出不必要在事務(wù)中的select操作
到此這篇關(guān)于mysql事務(wù)對(duì)效率的影響分析總結(jié)的文章就介紹到這了,更多相關(guān)mysql事務(wù)對(duì)效率的影響內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。