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

Mysql查詢時(shí)如何使用for update行鎖還是表鎖

 更新時(shí)間:2023年08月29日 10:21:03   作者:nacrt  
這篇文章主要介紹了Mysql查詢時(shí)如何使用for update行鎖還是表鎖問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

測(cè)試表

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');

測(cè)試1

用主鍵查詢時(shí)是行鎖

窗口1查詢id=1時(shí),窗口2查詢id=2時(shí)可以查詢,查詢id=1時(shí)會(huì)卡在那等待窗口1完成事務(wù)。

步驟1

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

步驟2

測(cè)試2

使用索引查詢時(shí)也是行鎖,鎖的是查到的行

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

步驟1

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

步驟2

測(cè)試3

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

索引失效

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

索引失效步驟1

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

索引失效步驟2

不使用索引

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

不使用索引查詢步驟1

不使用索引步驟2

結(jié)論

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

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

相關(guān)文章

  • MySQL數(shù)據(jù)庫8——數(shù)據(jù)庫中函數(shù)的應(yīng)用詳解

    MySQL數(shù)據(jù)庫8——數(shù)據(jù)庫中函數(shù)的應(yīng)用詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫8——數(shù)據(jù)庫中函數(shù)的應(yīng)用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 深入理解MySQL分區(qū)表的使用

    深入理解MySQL分區(qū)表的使用

    本文主要介紹了深入理解MySQL分區(qū)表的使用
    2024-03-03
  • Hibernate4在MySQL5.1以上版本創(chuàng)建表出錯(cuò) type=InnDB

    Hibernate4在MySQL5.1以上版本創(chuàng)建表出錯(cuò) type=InnDB

    本文主要介紹解決Hibernate4在MySQL5.1自動(dòng)創(chuàng)建表出錯(cuò)的方法,簡單實(shí)用,需要的朋友可以參考下。
    2016-05-05
  • MySQL之初始化數(shù)據(jù)詳解

    MySQL之初始化數(shù)據(jù)詳解

    本文介紹了MySQL命令行的基本操作,包括列出數(shù)據(jù)庫、創(chuàng)建數(shù)據(jù)庫、使用數(shù)據(jù)庫、查看表、刪除數(shù)據(jù)庫、退出MySQL等,還詳細(xì)介紹了數(shù)據(jù)庫表的結(jié)構(gòu)和屬性,以及如何創(chuàng)建和初始化測(cè)試數(shù)據(jù)
    2025-01-01
  • 最新評(píng)論