代码改变世界

mysql查询锁表及解锁

2015-07-21 17:28  NO.27  阅读(4955)  评论(0编辑  收藏  举报
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放到第一步之前。

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