亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL基礎教程之事務異常情況

 更新時間:2022年10月29日 09:02:56   作者:木木止月  
事務(Transaction)是訪問和更新數(shù)據庫的程序執(zhí)行單元;事務中可能包含一個或多個sql語句,這些語句要么都執(zhí)行,要么都不執(zhí)行,下面這篇文章主要給大家介紹了關于MySQL基礎教程之事務異常情況的相關資料,需要的朋友可以參考下

測試異常情況

-- 1. 查詢張三余額
select * from account where name = '張三';
-- 2. 張三的余額減少1000
update account set money = money - 1000 where name = '張三';
出錯了....
-- 3. 李四的余額增加1000
update account set money = money + 1000 where name = '李四';
  • 我們把數(shù)據都恢復到2000, 然后再次一次性執(zhí)行上述的SQL語句(出錯了.... 這句話不符合SQL語 法,執(zhí)行就會報錯),檢查最終的數(shù)據情況, 發(fā)現(xiàn)數(shù)據在操作前后不一致了。

控制事務一

查看/設置事務提交方式

SELECT @@autocommit ;
SET @@autocommit = 0 ;

提交事務

COMMIT;

回滾事務

ROLLBACK;

注意:

上述的這種方式,我們是修改了事務的自動提交行為, 把默認的自動提交修改為了手動提 交, 此時我們執(zhí)行的DML語句都不會提交, 需要手動的執(zhí)行commit進行提交。

控制事務二

開啟事務

START TRANSACTION 或 BEGIN ;

提交事務

COMMIT;

回滾事務

ROLLBACK;

轉賬案例:

-- 開啟事務
start transaction
-- 1. 查詢張三余額
select * from account where name = '張三';
-- 2. 張三的余額減少1000
update account set money = money - 1000 where name = '張三';
-- 3. 李四的余額增加1000
update account set money = money + 1000 where name = '李四';
-- 如果正常執(zhí)行完畢, 則提交事務
commit;
-- 如果執(zhí)行過程中報錯, 則回滾事務
-- rollback;

事務四大特性

  • 原子性(Atomicity):事務是不可分割的最小操作單元,要么全部成功,要么全部失敗。
  • 一致性(Consistency):事務完成時,必須使所有的數(shù)據都保持一致狀態(tài)。
  • 隔離性(Isolation):數(shù)據庫系統(tǒng)提供的隔離機制,保證事務在不受外部并發(fā)操作影響的獨立環(huán)境下運行。
  • 持久性(Durability):事務一旦提交或回滾,它對數(shù)據庫中的數(shù)據的改變就是永久的。上述就是事務的四大特性,簡稱ACID。

補充:Mysql 事務并發(fā)處理的三種異常

臟讀(Dirty Read)【一個事務可能讀取到另一個事務更新但未提交的數(shù)據,這個數(shù)據有可能是臟數(shù)據】

不可重復讀(Nnrepeatable Read)【事務不可重復讀同一條記錄,因為很可能讀到的結果不一致】

幻讀(Phantom Read)【幻讀就是沒有讀到的記錄,以為不存在,但其實是可以更新成功的,并且,更新成功后,再次讀取,就出現(xiàn)了?!?/p>

A1訪問數(shù)據庫,正在進行事務,往表B里加入一條記錄,但是還未提交該事務,此時A2也去訪問數(shù)據庫了,這個時候,A2可以看到A1加入的數(shù)據,這種現(xiàn)象就是臟讀。

A2訪問數(shù)據庫查看id=1的數(shù)據,這個時候A1訪問數(shù)據庫,開始了一個事務,更新了id=1的數(shù)據,且沒有提交。然后A2又去訪問數(shù)據庫查看id=1的數(shù)據,看到的數(shù)據跟第一次看到的數(shù)據不一樣,而是A1更新的數(shù)據,這種現(xiàn)象就是不可重復讀。

A2訪問數(shù)據庫,查看B表里的全部數(shù)據。這個時候A1又往B表里加一條記錄,開始了事務但是還未提交。這個時候A2又去查看了一下,就出現(xiàn)了A1加進去的但還未提交的數(shù)據,這種現(xiàn)象就是幻讀。

總結

到此這篇關于MySQL基礎教程之事務異常情況的文章就介紹到這了,更多相關MySQL事務異常情況內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • mysql緩沖和緩存設置詳解

    mysql緩沖和緩存設置詳解

    本文主要給大家講解的是mysql優(yōu)化過程中比較重要的2個參數(shù)緩沖和緩存的設置,希望大家能夠喜歡
    2016-12-12
  • Mysql ID生成策略的三種方法選擇及優(yōu)缺點

    Mysql ID生成策略的三種方法選擇及優(yōu)缺點

    mysql ID生成策略一般常用的有三種,包括自增、UUID 以及雪花算法,本文主要介紹了Mysql ID生成策略的三種方法選擇及優(yōu)缺點,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • MySQL取消了Query Cache的原因

    MySQL取消了Query Cache的原因

    這篇文章主要介紹了MySQL取消了Query Cache的原因,幫助大家更好的理解和使用MySQL數(shù)據庫,感興趣的朋友可以了解下
    2020-10-10
  • MySQL數(shù)據庫分庫分表的方案

    MySQL數(shù)據庫分庫分表的方案

    隨著項目不斷迭代,使用人數(shù)的不斷增加,數(shù)據庫中某些表數(shù)據正在逐步膨脹,往單表千萬迅速靠攏,,所以最近也在考慮做一下分庫分表,本文就給大家詳細講解了什么分庫分表和分庫分表的方案,需要的朋友可以參考下
    2023-11-11
  • mysql 動態(tài)執(zhí)行存儲過程語句

    mysql 動態(tài)執(zhí)行存儲過程語句

    MSSQL中動態(tài)執(zhí)行sql語句可以使用EXEC()函數(shù)。MSSQL中也有類似的函數(shù)EXECUTE(),不過不同的是MYSQL中動態(tài)執(zhí)行存儲過程語句與MSSQL還是有區(qū)別的。
    2009-07-07
  • MySQL對數(shù)據庫和表進行DDL命令的操作代碼

    MySQL對數(shù)據庫和表進行DDL命令的操作代碼

    DDL(Data?Definition?Language),是數(shù)據定義語言的縮寫,它是SQL(Structured?Query?Language)語言的一個子集,用于定義或修改數(shù)據庫的結構,本文給大家介紹了MySQL對數(shù)據庫和表進行DDL命令的操作,需要的朋友可以參考下
    2024-07-07
  • MySQL中varchar(n) 中n最大取值為多少

    MySQL中varchar(n) 中n最大取值為多少

    本文主要介紹了MySQL中varchar(n) 中n最大取值為多少
    2024-08-08
  • IDEA使用mybatis-generator及配上mysql8.0.3版本遇到的bug

    IDEA使用mybatis-generator及配上mysql8.0.3版本遇到的bug

    這篇文章主要介紹了IDEA使用mybatis-generator以及配上mysql8.0.3版本遇到的問題,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • MySQL8 臨時關閉緩存的方法實現(xiàn)

    MySQL8 臨時關閉緩存的方法實現(xiàn)

    在某些場景下,如基準測試、數(shù)據一致性檢查或高頻數(shù)據更新,可能需要臨時關閉緩存以獲得更準確的性能數(shù)據或解決性能問題,本文就詳細的介紹一下MySQL8 臨時關閉緩存的方法實現(xiàn),感興趣的可以了解一下
    2024-10-10
  • mysql 編碼設置命令

    mysql 編碼設置命令

    mysql 編碼設置命令,需要的朋友可以參考下。
    2009-10-10

最新評論