行级锁 表级锁 乐观锁 悲观锁

行级锁

行级锁一般是指排它锁,即被锁定行不可进行修改,删除,只可以被其他会话select。

访问数据库的时候 针对整个行数据

自动加锁。对于UPDATE、DELETE和INSERT语句,InnoDB会自动给涉及数据集加排他锁;对于普通SELECT语句,不会加任何锁。

优缺点

1.优点:

  • 由于锁粒度小,争用率低,并发高。(也就是可以大大减少数据库操作的冲突)

2.缺点:

  • 实现复杂,开销大。
  • 加锁慢、容易出现死锁。

表级锁

表级锁,一般是指表结构共享锁,是不可对该表执行DDL操作,但对DML操作都不限制。

访问数据库的时候 针对整个表数据

自动加锁。查询操作(SELECT),会自动给涉及的所有表加读锁,更新操作(UPDATE、DELETE、INSERT),会自动

给涉及的表加写锁。

优缺点

1.优点:

  • 开销小,加锁快,不会出现死锁。

2.缺点:

  • 锁的粒度大,发生锁冲突的概率高,并发度低。

悲观锁(加的是表级锁)

一方:查询语句加 for update;另一方:查询语句加 for update;当进行更新语句的时候,另一方不能进行更新操作

乐观锁

更新语句设置版本号,在指定版本中更新数据

一方:update account set money=money-200,version=version+1 where id=1 and version=0;

另一方操作同一个版本号,则不能更新数据

另一方:update account set money=money+200,version=version+1 where id=1 and version=0;

如果更新多,查询少,用悲观锁;反之,乐观锁

 

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值