mysql查询锁表及解锁

SHOW PROCESSLIST;
KILL ;

锁表网上解释:

这牵涉到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放到第一步之前。

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

上一篇:python实现学生选课系统 面向对象的应用:


下一篇:AR8033 1000M模式下ping包丢包率过大分析与解决