• 技术文章 >数据库 >MySQL

    mysql间歇锁是什么

    小妮浅浅小妮浅浅2021-08-14 09:49:14原创3109

    说明

    1、间隙锁是Innodb在提交下为了解决幻读问题时引入的锁机制。

    2、对于键值在条件范围内但并不存在的记录,在相等条件下请求给一个不存在的记录也会加锁,叫做间隙锁。

    实例

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    #session1 操作会话session1 开启事务

      

    mysql> begin;

      

    Query OK, 0 rows affected (0.00 sec)

      

    #session1 更新id=11的数据,获取行锁。

      

    mysql> select * from userinfo where id=11  for update;

      

    Empty set (0.00 sec)

      

       

      

    #session2 操作会话session2 开启事务

      

    mysql> begin;

      

    Query OK, 0 rows affected (0.00 sec)

      

    #session2 在会话session2 新增数据主键为12

      

    mysql> insert into userinfo values(12,'hh',18);

      

    .... 一直处于阻塞状态

      

    #如果等待时间过长,session1没有释放锁,会抛出如下异常。

      

    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    以上就是mysql间隙锁的介绍,希望对大家有所帮助。更多mysql学习指路:MySQL

    推荐操作系统:windows7系统、mysql5.8、DELL G3电脑

    专题推荐:mysql间歇锁
    上一篇:mysql char和varchar的应用场景 下一篇:mysql间歇锁的特性分析

    相关文章推荐

    • mysql游标的介绍• mysql光标如何使用• mysql中concat函数的用法• mysql字符串的大小写转换• mysql中trim函数的使用• mysql中instr()函数的使用• mysql中replace函数是什么• mysql中有哪些常见的原则• mysql加锁规则是什么• mysql char和varchar的应用场景

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网