溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Mysql數(shù)據(jù)庫(kù)中事務(wù)Update會(huì)鎖表嗎

發(fā)布時(shí)間:2020-12-14 15:23:56 來(lái)源:億速云 閱讀:520 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

Mysql數(shù)據(jù)庫(kù)中事務(wù)Update會(huì)鎖表嗎?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

兩種情況:

1.帶索引 2.不帶索引

前提介紹:

方式:采用命令行的方式來(lái)模擬

1.mysq由于默認(rèn)是開(kāi)啟自動(dòng)提交事務(wù),所以首先得查看自己當(dāng)前的數(shù)據(jù)庫(kù)是否開(kāi)啟了自動(dòng)提交事務(wù)。

命令:select @@autocommit;

結(jié)果如下:

+--------------+
| @@autocommit |
+--------------+
|  0 |
+--------------+

如果是1,那么運(yùn)行命令:set autocommit = 0;設(shè)置為不開(kāi)啟自動(dòng)提交

2.當(dāng)前的數(shù)據(jù)庫(kù)表格式如下

tb_user | CREATE TABLE `tb_user` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `name` varchar(32) DEFAULT NULL,
 `phone` varchar(11) DEFAULT NULL,
 `operator` varchar(32) DEFAULT NULL,
 `gmt_create` datetime DEFAULT NULL,
 `gmt_modified` datetime DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8

顯然除了主鍵,我沒(méi)有加任何索引

實(shí)際例子:

1.沒(méi)有索引

運(yùn)行命令:begin;開(kāi)啟事務(wù),然后運(yùn)行命令:update tb_user set phone=11 where name="c1";修改,先別commit事務(wù)。

再開(kāi)一個(gè)窗口,直接運(yùn)行命令:update tb_user set phone=22 where name=“c2”;會(huì)發(fā)現(xiàn)命令卡住了,但是當(dāng)前面一個(gè)事務(wù)通過(guò)commit提交了,命令就會(huì)正常運(yùn)行結(jié)束,說(shuō)明是被鎖表了。

2.給name字段加索引

create index index_name on tb_user(name);

然后繼續(xù)如1里面的操作,也就是一個(gè)開(kāi)啟事務(wù),運(yùn)行update tb_user set phone=11 where name="c1";先不提交

然后另一個(gè)運(yùn)行update tb_user set phone=22 where name="c2";發(fā)現(xiàn)命令不會(huì)卡住,說(shuō)明沒(méi)有鎖表

但是如果另一個(gè)也是update tb_user set phone=22 where name="c1";更新同一行,說(shuō)明是鎖行了

3.總結(jié)

如果沒(méi)有索引,所以u(píng)pdate會(huì)鎖表,如果加了索引,就會(huì)鎖行

關(guān)于Mysql數(shù)據(jù)庫(kù)中事務(wù)Update會(huì)鎖表嗎問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI