Mysql查詢時如何使用for update行鎖還是表鎖
測試表
CREATE TABLE `user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `username` varchar(255) DEFAULT NULL, `password` varchar(255) DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE, KEY `u_name_uq` (`username`) USING BTREE ) ENGINE=InnoDB; INSERT INTO `user`(`id`, `username`, `password`) VALUES (1, 'zhangsan', '123456'); INSERT INTO `user`(`id`, `username`, `password`) VALUES (2, 'zhangsi', 'abc456'); INSERT INTO `user`(`id`, `username`, `password`) VALUES (3, 'lisan', '123654');
測試1
用主鍵查詢時是行鎖
窗口1查詢id=1時,窗口2查詢id=2時可以查詢,查詢id=1時會卡在那等待窗口1完成事務(wù)。
窗口1提交事務(wù),窗口2就可以查出id=1的結(jié)果了
測試2
使用索引查詢時也是行鎖,鎖的是查到的行
當(dāng)窗口1根據(jù)username索引查詢到id=1和2的結(jié)果時,窗口2查詢id=3時可以查詢,查詢id=1和2時會卡住,等待窗口1的事務(wù)完成。
當(dāng)窗口1提交或回滾事務(wù)時,窗口2卡住的查詢就出現(xiàn)結(jié)果了。
測試3
當(dāng)索引失效或者是不使用索引時:鎖的是表
索引失效
當(dāng)使用like + %開頭的查詢時索引失效,窗口1查出id=1和3的數(shù)據(jù),窗口2查詢id=2的數(shù)據(jù)會卡住,說明整個表都被鎖了。
窗口1完成事務(wù),窗口2出現(xiàn)結(jié)果:
不使用索引
窗口1不適用任何索引查詢id=1的結(jié)果,窗口2查詢id=2的結(jié)果會卡住,說明還是表鎖
結(jié)論
在開啟事務(wù)的情況下,查詢使用for update,如果使用了索引(主鍵)并且索引生效的情況下,鎖的是查到的行,否則是表鎖。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL內(nèi)存及虛擬內(nèi)存優(yōu)化設(shè)置參數(shù)
這篇文章主要介紹了MySQL內(nèi)存及虛擬內(nèi)存優(yōu)化設(shè)置參數(shù),需要的朋友可以參考下2016-05-05Win10環(huán)境下安裝Mysql5.7.23問題及遇到的坑
這篇文章主要介紹了Win10環(huán)境下安裝Mysql5.7.23問題及遇到的坑,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-11-11MySQL實現(xiàn)導(dǎo)出excel的方法分析
這篇文章主要介紹了MySQL實現(xiàn)導(dǎo)出excel的方法,結(jié)合實例形式分析了基于php、js等方法實現(xiàn)mysql導(dǎo)出Excel的相關(guān)操作技巧,需要的朋友可以參考下2018-03-03MySql數(shù)據(jù)庫基礎(chǔ)之子查詢詳解
所謂子查詢是指在一個查詢中嵌套了其他的若干查詢,即在一個SELECT查詢語句的WHERE或FROM子句中包含另一個SELECT查詢語句,下面這篇文章主要給大家介紹了關(guān)于MySQL子查詢的相關(guān)資料,需要的朋友可以參考下2022-09-09MySQL數(shù)據(jù)庫8——數(shù)據(jù)庫中函數(shù)的應(yīng)用詳解
這篇文章主要介紹了MySQL數(shù)據(jù)庫8——數(shù)據(jù)庫中函數(shù)的應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Hibernate4在MySQL5.1以上版本創(chuàng)建表出錯 type=InnDB
本文主要介紹解決Hibernate4在MySQL5.1自動創(chuàng)建表出錯的方法,簡單實用,需要的朋友可以參考下。2016-05-05