mysql事務(wù)對(duì)效率的影響分析總結(jié)
1、數(shù)據(jù)庫(kù)事務(wù)會(huì)降低數(shù)據(jù)庫(kù)的性能。為了保證數(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ù)庫(kù)從一種一致性狀態(tài)轉(zhuǎn)換到另外一種一致性狀態(tài),在事務(wù)開(kāi)始之前和事務(wù)結(jié)束后數(shù)據(jù)庫(kù)中的完整性沒(méi)有被破壞
- 隔離性:要求一個(gè)事務(wù)對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)修改,在未提交完成前對(duì)其他事務(wù)是不可見(jiàn)的
- 持久性:一旦事務(wù)提交,則其所做的修改就會(huì)永久保存到數(shù)據(jù)庫(kù)中。此時(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)文章希望大家以后多多支持腳本之家!
相關(guān)文章
window上驗(yàn)證mysql是否安裝成功的操作過(guò)程
這篇文章主要介紹了window上驗(yàn)證mysql是否安裝成功,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-08-08
sql中替換函數(shù)replace()用法與實(shí)例總結(jié)
這篇文章主要給大家介紹了關(guān)于sql中替換函數(shù)replace()用法與實(shí)例的相關(guān)資料,在SQL中REPLACE函數(shù)用于替換一個(gè)字符串中的一部分為另一個(gè)字符串,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-02-02
MySQL數(shù)據(jù)庫(kù)備份過(guò)程的注意事項(xiàng)
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)備份過(guò)程的注意事項(xiàng),幫助大家更好的理解和維護(hù)MySQL,感興趣的朋友可以了解下2020-11-11
MySQL8.0設(shè)置redo緩存大小的實(shí)現(xiàn)
本文主要在MySQL 8.0.30及之后版本中使用innodb_redo_log_capacity參數(shù)在線更改redo緩存文件大小,下面就來(lái)介紹一下,具有一定的參考價(jià)值,感興趣的可以了解一下2025-02-02
MySQL中利用索引對(duì)數(shù)據(jù)進(jìn)行排序的基礎(chǔ)教程
這篇文章主要介紹了MySQL中利用索引對(duì)數(shù)據(jù)進(jìn)行排序的基礎(chǔ)教程,需要的朋友可以參考下2015-11-11
zabbix監(jiān)控MySQL主從狀態(tài)的方法詳解
這篇文章主要介紹了zabbix--監(jiān)控MySQL主從狀態(tài)的方法,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-06-06
MySQL中如何開(kāi)啟二進(jìn)制日志(Binlog)
本文詳細(xì)介紹了如何在不同操作系統(tǒng)(Windows、Linux、Docker)下開(kāi)啟MySQL的二進(jìn)制日志(Binlog),包括停止MySQL服務(wù)、編輯配置文件、創(chuàng)建日志文件目錄、啟動(dòng)服務(wù)以及驗(yàn)證Binlog是否開(kāi)啟2025-03-03
MySQL使用集合函數(shù)進(jìn)行查詢操作實(shí)例詳解
這篇文章主要介紹了MySQL使用集合函數(shù)進(jìn)行查詢操作,結(jié)合實(shí)例形式詳細(xì)分析了MySQL使用集合函數(shù)進(jìn)行的運(yùn)算與查詢操作使用技巧,需要的朋友可以參考下2018-06-06
關(guān)于clickhouse幾種create table的情況
這篇文章主要介紹了關(guān)于clickhouse幾種create table的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12

