zoukankan      html  css  js  c++  java
  • mysql查询锁表及解锁

    SHOW PROCESSLIST;
    KILL   4086;

    锁表网上解释:

    这牵涉到mysql的事务,简单通俗的话,就这样给你解释
    有一个任务序列控制sql语句的执行,
    第一次有select的语句查询表a,mysql服务器在执行select之前将表a加读锁,
    第二次又有一条select语句查询表a, mysql服务器发现在任务序列中有表a的读锁,也就是同时还有一个sql查询表a,读锁不会影响这条sql语句,
    当有一条update或者insert语句对表a操作时,mysql服务器会对表a加写锁,以此提示之后的对表a操作的sql语句等待写锁解锁后在执行,以免造成写入与读取的混乱  

    我遇到的问题:

    语句完全没问题,但是偏偏锁住了。我的代码结构是 1:打开事务 2:查询A表ID 3:插入A表 4:插入B表 5:关闭事务

    通过上面的解释我觉得可能是我第二步放到事务里面了,所以我将第二步查询A表ID放到第一步之前。

    这个方法目前还没有问题不知道是不是这个原因,有懂得帮忙解释下。

  • 相关阅读:
    YII框架学习(二)
    YII框架学习(一)
    valid number 判断字符串是否为有效数字
    leetcode Add Binary
    leetcode Minimum Path Sum
    leetcode Unique Paths II
    leetcode[61] Unique Paths
    leetcode[60] Rotate List
    leetcode Permutation Sequence
    leetcode Spiral Matrix II
  • 原文地址:https://www.cnblogs.com/no27/p/4665103.html
Copyright © 2011-2022 走看看