mysql事务未提交会锁表吗(Mysql事务中Update是否会锁表?)
mysql事务未提交会锁表吗
Mysql事务中Update是否会锁表?两种情况:
1.带索引 2.不带索引
前提介绍:
方式:采用命令行的方式来模拟
1.mysq由于默认是开启自动提交事务,所以首先得查看自己当前的数据库是否开启了自动提交事务。
命令:select @@autocommit;
结果如下:
|
+ --------------+ | @@autocommit | + --------------+ | 0 | + --------------+ |
如果是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事务中Update是否会锁表的文章就介绍到这了,更多相关Mysql事务Update锁表内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://blog.csdn.net/agonie201218/article/details/109022700
- mysql的decimal类型(MySQL数据类型DECIMAL用法详解)
- mysql怎么看脱机数据(MYSQL电话号码,身份证数据脱敏的实现)
- mysql中怎么删除整张表(MySQL如何优雅的删除大表实例详解)
- php7用什么替代mysql(mysqli扩展无法在PHP7下升级问题的解决)
- mysql创建数据库基本指令(MySql 新建用户与数据库的实际操作步骤)
- mysql字符类型长度限制
- mysql高级概念(MySQL 自定义变量的概念及特点)
- mysql日志功能介绍(mysql日志系统的简单使用教程)
- centosdocker镜像安装mysql(linux下利用Docker安装mysql的步骤)
- mysql数据库简单优化(MySQL数据类型优化原则)
- 深入理解mysql日志(mysql 重要日志文件汇总)
- mysql查询逗号分割字符串(MySQL 字符串拆分实例无分隔符的字符串截取)
- mysqldump备份缺点(MySQL5.7 mysqldump备份与恢复的实现)
- myeclipse连接mysql数据库的方法(教你用eclipse连接mysql数据库)
- python操作mysql连接池(详解Python连接MySQL数据库的多种方式)
- mysql各种查询方式(mysql查询的控制语句图文详解)
- 今天要吃什么(今天要吃什么菜)
- 营养餐是什么(学校营养餐是什么)
- 谁说女子不如男 范冰冰演的武则天只是其一,另外两位你认识吗(谁说女子不如男)
- 杯酒人生---瓦伦丁酒杯和奥丁格啤酒(杯酒人生---瓦伦丁酒杯和奥丁格啤酒)
- 中秋节买啤酒,预算超过7元试试这8种啤酒,麦香浓郁都是真啤酒(预算超过7元试试这8种啤酒)
- CellPress旗下的6 期刊,国人友刊来了解一下吧(CellPress旗下的6期刊国人友刊来了解一下吧)
热门推荐
- python使用pandas数据分析系列(python使用pandas处理大数据节省内存技巧推荐)
- docker 无法启动(Docker 常见问题解决)
- 外企面试需要注意什么
- django整合前端流程日志权限(使用Django开发简单接口实现文章增删改查)
- sqlcount函数转化为数值型(SQL判断是否"存在",还在用 count 操作?很耗时的!)
- 菲律宾云服务器价格(菲律宾云服务器适合用来做什么?)
- docker配置源不生效(解决docker CMD/ENTRYPOINT执行sh脚本报: not found/run.sh:)
- Docker 运行多个Springboot的详细教程(Docker 运行多个Springboot的详细教程)
- sqlserver触发器编写(SQLSever中的触发器基本语法与作用)
- .Net中Immutable(不可变)集合
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9