mysql中的limit 1 for update的锁类型

 更新时间:2023年08月29日 16:47:31   作者:luwei9233  
这篇文章主要介绍了mysql中的limit 1 for update的锁类型,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql limit 1 for update的锁类型

最近遇到一个业务问题,购物券号是预先产生的,然后进行客户ID的绑定,从SQL上来讲基本上有两种方式实现

方式一

begin;
select * from purchase_code where code_type = 0 limit 1 for update;
update purchase_code set code_type=1,user_id=123 where purchase_code_id = 1
commit

方式二

update purchase_code set code_type=1,user_id=123 where code_type=0 limit 1;

之前一直担心方式一会出现问题;主要是担心会因为并发问题,导致选出来的行被其他线程所修改掉,因为一直会觉得第一种方式加的是行锁,需要查出来继续判断一下code_type才能进行更新。

进行测试了一下发现上面两种方式加的都是表锁。

因为什么原因上面加的是表锁呢?

经过测试,mysql加锁有这样的特点:

主键查询加行锁

begin;
select * from t_user_role where role_id = "1111" limit 1 for update ;

此时可以对其他行加读锁和写锁

select * from t_user_role where role_id = 'operator';
select * from t_user_role where role_id = 'operator' for update

锁升级的情况

role_id为varchar类型,但是用int类型也能搜索出来,但是此时加的是表锁

select * from t_user_role where role_id = 1111 for update;

当按非主键查询的时候,此时mysql加的是表锁

此时下面的查询都会卡住

select * from t_user_role where role_type = 2 limit 1 for update ;
select * from t_user_role where role_id = 'operator' for update;

如果对role_type加上一个key索引,情况就变得有意思

除了最后一次查询被卡住外,其他查询全部能返回

select * from t_user_role where role_type = 2 limit 1 for update ;
select * from t_user_role where role_id = 'operator' for update;
select * from t_user_role where role_id = '2222' for update;
select * from t_user_role where role_type = 1 limit 1 for update ;

研究innodb的锁机制发现

innodb是通过索引实现行锁,只有通过索引项查询的时候,才会加行锁,否则统一加的是表锁。

因此role_type上加索引之后,锁加在了role_type的索引上,从而上面其他三能顺利获得锁,但是此时已然无法获取表锁

mysql update limit 批量修改数据

1、想要实现修改数据库的5条之后的数据

update demo set flag='1' where user_id=1 limit 5,100;

上面这句测试了是错误的,MYSQL的UPDATE语句不能update限制从第N(5)条之后开始更新N(100)条。

2、建议方法

可以改变一下思维方式

  • 1)先将全部flag修改为flag=1; 
  • 2)再按自己需求修改前N条,或者后N条数据falg=0;

①、

update demo set flag='1'  where user_id = 1;

②、

修改数据前5条:

update demo set flag='1' where user_id=1 and flag='0' limit 5;

修改数据后5条:

update demo set flag='1' where user_id=1 and flag='0' order by id desc limit 5;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL 原理与优化之Update 优化

    MySQL 原理与优化之Update 优化

    这篇文章主要介绍了MySQL 原理与优化之Update 优化,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下,希望对你的学习有所帮助
    2022-08-08
  • MySQL索引失效的14种场景分享

    MySQL索引失效的14种场景分享

    作为一名后端程序员,经常会对慢查询SQL语句进行调优,而SQL语句出现慢查询,很多情况是由于索引失效造成的,本文为大家整理了14种MySQL索引失效的场景,需要的可以参考一下
    2023-05-05
  • MySql增量恢复的几种实现方法

    MySql增量恢复的几种实现方法

    本文主要介绍了MySql增量恢复的几种实现方法,通过增量备份与恢复,可以在系统发生故障或数据损坏时快速恢复到最新状态,提高系统的可靠性和可用性,感兴趣的可以了解一下
    2023-08-08
  • mysql复制表的几种常用方式总结

    mysql复制表的几种常用方式总结

    mysql想必大家比较熟悉了,我们常见的crud sql想必大家也是手到拈来,下面这篇文章主要给大家介绍了关于mysql复制表的几种常用方式,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • MySQL查询中LIMIT的大offset导致性能低下浅析

    MySQL查询中LIMIT的大offset导致性能低下浅析

    这篇文章主要给大家介绍了关于MySQL查询中LIMIT的大offset导致性能低下的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-12-12
  • MySQL锁机制与用法分析

    MySQL锁机制与用法分析

    这篇文章主要介绍了MySQL锁机制与用法,较为详细的分析了mysql锁机制的分类、原理及相关使用技巧,需要的朋友可以参考下
    2018-04-04
  • 数据库索引的知识点整理小结,你所需要了解的都在这儿了

    数据库索引的知识点整理小结,你所需要了解的都在这儿了

    这篇文章主要介绍了数据库索引的知识点整理小结,你所需要了解的都在这儿了,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-07-07
  • MySQL判别InnoDB表是独立表空间还是共享表空间的方法详解

    MySQL判别InnoDB表是独立表空间还是共享表空间的方法详解

    这篇文章主要给大家介绍了关于MySQL判别InnoDB表是独立表空间还是共享表空间的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
    2018-09-09
  • MySQL模式 Strict Mode知识点详解

    MySQL模式 Strict Mode知识点详解

    在本篇文章里小编给各位整理的是一篇关于MySQL模式 Strict Mode知识点详解内容,需要的朋友们参考下。
    2020-03-03
  • mysql 带多个条件的查询方式

    mysql 带多个条件的查询方式

    这篇文章主要介绍了mysql 带多个条件的查询方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06

最新评论