您现在的位置是:群英 > 数据库 > MySQL数据库
MySQL锁表有哪些原因,为何会这样
Admin发表于 2022-05-14 11:37:313202 次浏览
在实际案例的操作过程中,我们可能会遇到“MySQL锁表有哪些原因,为何会这样”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看看吧。



在mysql中,锁表的原因是一个程序执行了对表的insert、update或者delete操作还未commite时,另一个程序也对同一个表进行相同的操作,则此时会发生资源正忙的异常,也就是锁表。

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

mysql锁表的原因是什么

锁是计算机协调多个进程或线程并发访问某一资源的机制。

在数据库中,除传统的计算资源(如CPU、RAM、I/O等)的争用以外,数据也是一种供许多用户共享的资源。

如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因素。

从这个角度来说,锁对数据库而言显得尤其重要,也更加复杂。

锁表的原因

1、锁表发生在insert update 、delete 中

2、锁表的原理是 数据库使用独占式封锁机制,当执行上面的语句时,对表进行锁住,直到发生commite 或者 回滚 或者退出数据库用户

  第一、 A程序执行了对 tableA 的 insert ,并还未 commite时,B程序也对tableA 进行insert 则此时会发生资源正忙的异常 就是锁表

  第二、锁表常发生于并发而不是并行(并行时,一个线程操作数据库时,另一个线程是不能操作数据库的,cpu 和i/o 分配原则)

3、减少锁表的概率:

  减少insert 、update 、delete 语句执行 到 commite 之间的时间。

  具体点批量执行改为单个执行、优化sql自身的非执行速度 如果异常对事物进行回滚

示例如下:

使用 update

  假设kid 是表table 的 一个索引字段 且值不唯一:

  1):如果kid 有多个值为12的记录那么:

    update table set name=’feie’ where kid=12; #会锁表

  2):如果kid有唯一的值为1的记录那么:

    update table set name=’feie’ where kid=1; #不会锁

总结:用索引字段做为条件进行修改时, 是否表锁的取决于这个索引字段能否确定记录唯一,当索引值对应记录不唯一,会进行锁表,相反则行锁。

使用 delete

  如果有两个delete : kid1 与 kid2 是索引字段

  1):语句1 delete from table where kid1=1 and kid2=2;

  2):语句2 delete from table where kid1=1 and kid2=3;

     # 这样的两个delete 是不会锁表的

  1):语句1 delete from table where kid1=1 and kid2=2;

  2):语句2 delete from table where kid1=1 ;

     # 这样的两个delete 会锁表

总结:同一个表,如果进行删除操作时,尽量让删除条件统一,否则会相互影响造成锁表


到此这篇关于“MySQL锁表有哪些原因,为何会这样”的文章就介绍到这了,感谢各位的阅读,更多相关MySQL锁表有哪些原因,为何会这样内容,欢迎关注群英网络资讯频道,小编将为大家输出更多高质量的实用文章!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: mysql锁表
相关信息推荐
2022-06-20 17:06:08 
摘要:Union是一种SQL运算符,用于将多个SELECT语句的结果组合成一个结果集,其语法是“UNION ALL SELECT * FROM TableB UNION SELECT * FROM TableC”。
2022-05-16 17:20:15 
摘要:在oracle中,可以利用select语句查询连接数,该语句用于返回在指定条件下的查询结果,是oracle常用的查询语句,语法为“select count(*) from v$process”。
2022-08-15 17:35:08 
摘要:方法:1、利用“revoke system_privilege from user|role”命令取消系统权限;2、利用“revoke obj_privilege|allon object from user|role”命令取消对象权限。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部