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

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

转载于:https://www.cnblogs.com/no27/p/4665103.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值