• 技术文章 >数据库 >mysql教程

    mysql中update会锁表吗

    长期闲置长期闲置2022-05-26 14:42:36原创187

    mysql中update会不会锁表的两种情况:1、update没有索引时,语句前面一个事务通过commit提交,命令会正常运行结束,则update会锁表;2、update添加索引时,命令不会卡住,不会锁表,但会更新同一行导致锁行。

    本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。

    mysql中update会锁表吗

    如果没有索引,所以update会锁表,如果加了索引,就会锁行

    当前面一个事务通过commit提交了,命令就会正常运行结束,说明是被锁表了。

    两种情况:

    前提介绍:

    方式:采用命令行的方式来模拟

    1.mysq由于默认是开启自动提交事务,所以首先得查看自己当前的数据库是否开启了自动提交事务。

    命令:select @@autocommit;

    结果如下:

    28.png

    如果是1,那么运行命令:set autocommit = 0;设置为不开启自动提交

    2.当前的数据库表格式如下

    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

    显然除了主键,我没有加任何索引

    实际例子:

    1.没有索引

    运行命令:begin;开启事务,然后运行命令:update tb_user set phone=11 where name="c1";修改,先别commit事务。

    再开一个窗口,直接运行命令:update tb_user set phone=22 where name=“c2”;会发现命令卡住了,但是当前面一个事务通过commit提交了,命令就会正常运行结束,说明是被锁表了。

    2.给name字段加索引

    create index index_name on tb_user(name);

    然后继续如1里面的操作,也就是一个开启事务,运行update tb_user set phone=11 where name="c1";先不提交

    然后另一个运行update tb_user set phone=22 where name="c2";发现命令不会卡住,说明没有锁表

    但是如果另一个也是update tb_user set phone=22 where name="c1";更新同一行,说明是锁行了

    3.总结

    如果没有索引,所以update会锁表,如果加了索引,就会锁行

    推荐学习:mysql视频教程

    以上就是mysql中update会锁表吗的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:mysql
    上一篇:MySQL主从延迟、读写分离的解决方法总结 下一篇:mysql中pid文件丢失怎么办
    php培训_php实战培训【立即报名】-php中文网第20期

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• mysql5.6怎么修改字符集• mysql怎么设置时间查询条件• mysql怎么转换为sqlite• mysql怎么修改definer• mysql5.7怎么修改root密码
    1/1

    PHP中文网