事务中的锁,行锁与表锁

34 篇文章 0 订阅

当执行事务时,相当于执行了锁,来保持数据的一致性,但是锁分多种,有行锁,表锁。行锁就是只锁定那一行,那一条记录,别的连接下的操作还可以操作这张表。表锁就是锁定整张表,只有当前连接执行完事务,才可以解锁。

 

就效率而然,当然是行锁好,适用与多线程和高并发的情况,不过行锁对数据库会带来额外的开销。表锁高并发就差一点了,但单个的话快一点。

 

mysql为例,有索引并且使用了该索引当条件的时候就是行锁没有索引的时候就是表锁innodb 的行锁是在有索引的情况下,没有索引的表是锁定全表的.

 

锁是对于别的连接来说,不是对于当前连接,即当前连可以一直不加rollbackcommit,一路更新,但是别的连接就不行,必须等加了锁的连接释放(rollbackcommit)后才能更新,插入

 

建议:对于插入操作,一般加表锁,但是对于修改和删除操作,最好加行锁,这样在高并发时,不用等太久

 

加锁方式:

select from testlock where id=1 for update;——查询加锁,查询时不允许更改,该语句在自动提交为off或事务中生效,相当于更改操作,模拟加锁

update testlock name=name;——列=同一个列

更新操作,插入,删除操作,在事务中均属于加锁

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值