日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql update nowait_MySQL 8.0新特性 -- nowait以及skip locked

發(fā)布時間:2024/7/23 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql update nowait_MySQL 8.0新特性 -- nowait以及skip locked 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

如果某行記錄被事務(wù)鎖住了,select ... for update、或select ... for share事務(wù)對相同的行加鎖的時候必須等待,直到產(chǎn)生阻塞的事務(wù)釋放鎖。

為了避免等待事務(wù)釋放鎖定的行,nowait和skip locked選項可以被用于select ... for update或select ... for share語句:

·nowait:使用了nowait選項的鎖定讀操作,會立即執(zhí)行,如果讀的記錄被鎖定了就會報錯

·skip locked:使用了skip locked選項的鎖定讀操作,會立即執(zhí)行,如果讀的記錄被鎖定了就會從結(jié)果集移除該記錄。返回的數(shù)據(jù)是非一致性的。因此,不適用于常規(guī)的事務(wù)。

nowait和skip locked只適用于行級鎖。

nowait和skip locked對于基于語句的復(fù)制是不安全的。

# Session 1:

mysql> CREATE TABLE t (i INT, PRIMARY KEY (i)) ENGINE = InnoDB;

mysql> INSERT INTO t (i) VALUES(1),(2),(3);

mysql> START TRANSACTION;

mysql> SELECT * FROM t WHERE i = 2 FOR UPDATE;

+---+

| i |

+---+

| 2 |

+---+

# Session 2:

mysql> START TRANSACTION;

mysql> SELECT * FROM t WHERE i = 2 FOR UPDATE NOWAIT;

ERROR 3572 (HY000): Do not wait for lock.

# Session 3:

mysql> START TRANSACTION;

mysql> SELECT * FROM t FOR UPDATE SKIP LOCKED;

+---+

| i |

+---+

| 1 |

| 3 |

+---+

總結(jié)

以上是生活随笔為你收集整理的mysql update nowait_MySQL 8.0新特性 -- nowait以及skip locked的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。