zoukankan      html  css  js  c++  java
  • mysql表锁、行锁、索引之间暧昧的关系

    MySQL的innodb存储引擎支持行级锁,innodb的行锁是通过给索引项加锁实现的,这就意味着只有通过索引条件检索数据时,innodb才使用行锁,否则使用表锁。
    根据当前的数据更新语句(UPDATE user set name='11111' where account='1'),该条件字段account并没有添加索引,所以导致数据表被锁。

    我们验证一下:

    第一种情况,通过非索引条件检索数据时,使用的是表锁,会导致数据表被锁

    1.首先,我们将mysql事务设置为不自动提交,mysql事务默认是自动提交事务的,1表示自动提交事务

    mysql> select @@autocommit;
    +--------------+
    | @@autocommit |
    +--------------+
    |            1 |
    +--------------+
    1 row in set
    mysql> set autocommit = 0
    ;
    Query OK, 0 rows affected

    2.起一个命令行,开始事务,更新第一条记录,先不提交

    mysql> start transaction;
    Query OK, 0 rows affected
    
    mysql> beg
    in;
    Query OK, 0 rows affected
    
    mysql> UPDATE user set name='11111' where account='1'
        -> 

    3.我们再起一个命令行,更新第二条记录

    UPDATE user set name='2222' where id='2'

    4.看下表的数据

    可以看到,数据表没有更新

    5.把第一个命令行的事务提交了

    mysql> commit;
    Query OK, 0 rows affected

    我们看到现在数据更新了。

    第二种情况,通过索引条件检索数据时,使用的是行锁

    如第一种情况,自己测试下。

    
    
  • 相关阅读:
    php内核为变量的值分配内存的几个宏
    php7 引用成为一种类型
    function参数
    execvp php-fpm reload使用的函数
    fastcgi
    php-fpm定时器
    php 类继承
    php 对象 调用静态方法
    php unset变量
    php5数组与php7数组区别
  • 原文地址:https://www.cnblogs.com/tinyj/p/9855534.html
Copyright © 2011-2022 走看看