首頁  >  文章  >  後端開發  >  mysql並發加for update 沒有鎖住

mysql並發加for update 沒有鎖住

WBOY
WBOY原創
2016-08-10 09:07:231436瀏覽

我有一個長事務
在裡面中後段一個行級鎖
經測試,發現並沒有鎖住
但是單獨拿出這部分,又可以鎖住
在我整個長事務中,什麼情況下會影響我的加鎖嗎?
select Id from product_term where Id=".$v['P_Term_id']." for update

回覆內容:

我有一個長事務
在裡面中後段一個行級鎖
經測試,發現並沒有鎖住
但是單獨拿出這部分,又可以鎖住
在我整個長事務中,什麼情況下會影響我的加鎖嗎?
select Id from product_term where Id=".$v['P_Term_id']." for update

設定會影響。
其實。 。先問個小白的問題。 。 。是Innodb麼?之前遇到個Myisam問事務的問題。 。
好啦。回歸正題。
排它鎖正常是會鎖住這個查詢範圍直到事務結束的。
就像你這個。會鎖住對應ID行的那筆記錄。
不過根據事務的隔離模式。如果你沒改過設置,預設是RR的。也就是你在這個排它鎖之前,執行的SELECT是相同的結果。 。這就會有沒鎖住的假象產生。 。

假如你事務是這樣的

<code>BEGIN;
SELECT id FROM product_term where id<100;
UPDATE product_term SET XXX='YYY' WHERE id = 1;
...
SELECT id FROM product_term where id=1 FOR UPDATE;
...
COMMIT;</code>

像這種,由於預設RR級,第一個範圍搜已經包含了id=1的,然後同一個事務下第三個得出來的行會和第一行一樣。而實際上第二行已經改過這行的資料了。如果在2個並發下,就可能造成看起來表沒鎖住的現象~~
排他建議在事務開始的時候做。
不知道你遇到的是不是這個問題?如果是,可以仔細研究下事務的隔離模式,你會發現還有更多的坑

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn