Mysql事務

  • 什么是事務?

    \color{#0000FF}{事務是邏輯上的一組操作栅屏,要么都執(zhí)行要么都不執(zhí)行本今。}
  • 事務的4大特性

  1. \color{#FF34B3}{原子性(Atomic)}

    ???原子性指事務所包含的操作要么全部成功,要么全部失敗回滾。

  2. \color{#FF34B3}{隔離性(Isolation)}

    ???隔離性是指當多個用戶并發(fā)操作數(shù)據(jù)庫的時候仆潮,為每個用戶開啟的事務愧哟,不影響其他事務靴庆,多個事務之間相互隔離讲逛。

  3. \color{#FF34B3}{一致性(Consistency)}

???事務開始前和結束后,數(shù)據(jù)的完整性約束沒有被破壞店诗。

  1. \color{#FF34B3}{持久性(Durability)}

???事務一旦被提交裹刮,對數(shù)據(jù)庫中的改變是永久性的,即使是在數(shù)據(jù)庫系統(tǒng)遇到故障的情況下也不會丟失提交事務的操作庞瘸。

  • 并發(fā)事務帶來的問題

  1. 臟讀: ???? 如果有兩個事務A,B. A事務先開始捧弃,對數(shù)據(jù)做了修改但是沒有提交,此時B事務開始擦囊,讀取到了A事務修改但未提交的事務违霞,那么B事務讀取到的數(shù)據(jù)根本是不被承認的,此時B讀取到的數(shù)據(jù)為臟數(shù)據(jù)瞬场。
  2. 不可重復度: ???? 事務A多次讀取同一數(shù)據(jù)买鸽,事務B在事務A多次讀取之后,對數(shù)據(jù)做了更改贯被,導致事務A在下次讀取數(shù)據(jù)的時候眼五,與上次讀取的數(shù)據(jù)結果不一致妆艘。
  3. 幻讀: ????A事務讀取B事務提交的新增數(shù)據(jù),這是A事務出現(xiàn)幻讀看幼。
    小結: \color{#EE6363}{不可重復讀的重點是修改,幻讀的重點在與新增或者刪除}
  • 事務的隔離級別有哪些?Mysql的默認隔離級別是批旺?

事務級別 描述 臟讀 不可重復讀 幻讀
READ-UNCOMMITTED(讀取未提交) 最低的隔離級別,允許讀取尚未提交的數(shù)據(jù)變更 Y Y Y
READ-COMMITTED(讀取已提交) 允許讀取并發(fā)事務讀取已經提交的事務 N Y Y
REPEATABLE-READ(可重復讀) 對同一字段的多次讀取結果是一致的诵姜,除非數(shù)據(jù)是被事務自身修改 N N Y
SERIALIZABLE(可串行化) 最高的隔離級別朱沃,完全符合AICD,所有事務逐個執(zhí) N N N

Mysql InnoDB 存儲引擎的默認隔離級別是REPEATABLE-READ茅诱。

mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation  |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set (0.00 sec)
 
mysql> 

\color{ #FF0000}{注意}: mysql的REPEATABLE-READ的事務級別是使用的Next-Key Lock鎖算法,因此可以避免幻讀的發(fā)生搬卒。
補充:
可以通過 set session transaction isolation level 設置事務的隔離級別

mysql> set session transaction isolation level read committed;
Query OK, 0 rows affected (0.00 sec)
 
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
 
mysql> update student_score set score=99 where id=26;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0
 
mysql> commit;
Query OK, 0 rows affected (0.04 sec)
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末瑟俭,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子契邀,更是在濱河造成了極大的恐慌摆寄,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件坯门,死亡現(xiàn)場離奇詭異微饥,居然都是意外死亡,警方通過查閱死者的電腦和手機古戴,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評論 3 399
  • 文/潘曉璐 我一進店門欠橘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人现恼,你說我怎么就攤上這事肃续。” “怎么了叉袍?”我有些...
    開封第一講書人閱讀 168,386評論 0 360
  • 文/不壞的土叔 我叫張陵始锚,是天一觀的道長。 經常有香客問我喳逛,道長瞧捌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,726評論 1 297
  • 正文 為了忘掉前任润文,我火速辦了婚禮姐呐,結果婚禮上,老公的妹妹穿的比我還像新娘转唉。我一直安慰自己皮钠,他們只是感情好,可當我...
    茶點故事閱讀 68,729評論 6 397
  • 文/花漫 我一把揭開白布赠法。 她就那樣靜靜地躺著麦轰,像睡著了一般乔夯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上款侵,一...
    開封第一講書人閱讀 52,337評論 1 310
  • 那天末荐,我揣著相機與錄音,去河邊找鬼新锈。 笑死甲脏,一個胖子當著我的面吹牛,可吹牛的內容都是我干的妹笆。 我是一名探鬼主播块请,決...
    沈念sama閱讀 40,902評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼拳缠!你這毒婦竟也來了墩新?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,807評論 0 276
  • 序言:老撾萬榮一對情侶失蹤窟坐,失蹤者是張志新(化名)和其女友劉穎海渊,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哲鸳,經...
    沈念sama閱讀 46,349評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡臣疑,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,439評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了徙菠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片讯沈。...
    茶點故事閱讀 40,567評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖婿奔,靈堂內的尸體忽然破棺而出芙盘,到底是詐尸還是另有隱情,我是刑警寧澤脸秽,帶...
    沈念sama閱讀 36,242評論 5 350
  • 正文 年R本政府宣布儒老,位于F島的核電站,受9級特大地震影響记餐,放射性物質發(fā)生泄漏驮樊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,933評論 3 334
  • 文/蒙蒙 一片酝、第九天 我趴在偏房一處隱蔽的房頂上張望囚衔。 院中可真熱鬧,春花似錦雕沿、人聲如沸练湿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽肥哎。三九已至辽俗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間篡诽,已是汗流浹背崖飘。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留杈女,地道東北人朱浴。 一個月前我還...
    沈念sama閱讀 48,995評論 3 377
  • 正文 我出身青樓,卻偏偏與公主長得像达椰,于是被迫代替她去往敵國和親翰蠢。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,585評論 2 359

推薦閱讀更多精彩內容