欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql查詢時如何使用for update行鎖還是表鎖

 更新時間:2023年08月29日 10:21:03   作者:nacrt  
這篇文章主要介紹了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

窗口1提交事務(wù),窗口2就可以查出id=1的結(jié)果了

步驟2

測試2

使用索引查詢時也是行鎖,鎖的是查到的行

當(dāng)窗口1根據(jù)username索引查詢到id=1和2的結(jié)果時,窗口2查詢id=3時可以查詢,查詢id=1和2時會卡住,等待窗口1的事務(wù)完成。

步驟1

當(dāng)窗口1提交或回滾事務(wù)時,窗口2卡住的查詢就出現(xiàn)結(jié)果了。

步驟2

測試3

當(dāng)索引失效或者是不使用索引時:鎖的是表

索引失效

當(dāng)使用like + %開頭的查詢時索引失效,窗口1查出id=1和3的數(shù)據(jù),窗口2查詢id=2的數(shù)據(jù)會卡住,說明整個表都被鎖了。

索引失效步驟1

窗口1完成事務(wù),窗口2出現(xiàn)結(jié)果:

索引失效步驟2

不使用索引

窗口1不適用任何索引查詢id=1的結(jié)果,窗口2查詢id=2的結(jié)果會卡住,說明還是表鎖

不使用索引查詢步驟1

不使用索引步驟2

結(jié)論

在開啟事務(wù)的情況下,查詢使用for update,如果使用了索引(主鍵)并且索引生效的情況下,鎖的是查到的行,否則是表鎖。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論