MySql类型转换导致行锁升级为表锁


当前第2页 返回上一页

1

>update student set age=28 where name='lzj';

正常情况下,两条SQL语句操作的行数据不同,执行起来会互不影响,但实际会话1中的更新操作阻塞了会话2中的更新操作
1.png会话1中执行了更新操作,但没有执行事务提交,事务的隔离级别为Read Committed,所以在会话2中还看不到会话1中更新后的结果。但在回话2中执行对其它行数据更新操作时,出现了阻塞。可见会话1中的SQL语句的赋值出现了强转,导致会话1由行锁升级为表锁,锁住了整个student表,因而会话2中的SQL阻塞。下面对会话1中的更新操作执行事务提交,那么会话2中的更新操作就会继续执行了
1.png对会话1中的更新操作执行commit手动提交事务后,会话1释放掉student的表锁,会话2中的更新操作可以继续执行。
最后对会话2中的更新也执行commit事务提交,两条SQL都更新完毕,student表内容如下:
1.png

从上述案例观知,SQL语句赋值与表列类型不匹配时,MySql的优化器强制转化为匹配的类型,导致行锁升级为表锁。所以开发中一定要注意类型的匹配,避免行锁升级为表锁,影响并发性能。

相关推荐:

MySQL行级锁、表级锁、页级锁详细介绍

MySQL锁的用法之表级锁

以上就是MySql类型转换导致行锁升级为表锁的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

mysql的ddl操作

mysql事务管理的介绍(附示例)

mysql关于加密解密的函数

详解mysql中url时区的陷阱该如何规避

navicat for mysql怎么建立多表链接

phpmyadmin 1045错误无法登录mysql服务器怎么办

mysql存储过程的优点是什么

mysql视图如何修改

mysql 复制原理与实践应用详解

mysql 中查看表结构的命令有哪些

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    暂无评论...