悲观锁、乐观锁、行级锁、表级锁
来源:互联网 发布:南开大学 出国 知乎 编辑:程序博客网 时间:2024/05/20 21:21
更新丢失:新改的覆盖先改的,开发中有三种方法解决
1、将事务级别提高到最高级别TRANSACTION_SERIALIZABLE
操作双方都要提升级别;查询使用共享锁;更新使用更新锁;一方查询,一方更新,共享锁和更新锁会冲突;当双方更新锁,出现死锁,程序会自动回滚一方操作,从而避免更新丢失
2、悲观锁(加的是表级锁)
一方:查询语句加 for update;另一方:查询语句加 for update;当进行更新语句的时候,另一方不能进行更新操作
3、乐观锁
更新语句设置版本号,在指定版本中更新数据
一方: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;
如果更新多,查询少,用悲观锁;反之,乐观锁
表级锁,where用的是非主键
行级锁,where用主键一般是id
如果用表级锁,其他客户将不能进行查询操作,因此开发中记得用行级锁
- 悲观锁、乐观锁、行级锁、表级锁
- 悲观锁、乐观锁、行级锁、表级锁
- 悲观锁乐观锁
- 乐观锁,悲观锁
- 悲观锁 乐观锁
- 乐观锁 悲观锁
- 悲观锁-乐观锁
- 乐观锁 悲观锁
- 悲观锁,乐观锁
- 悲观锁乐观锁
- 乐观锁 悲观锁
- 悲观锁 乐观锁
- 悲观锁 乐观锁
- 悲观锁乐观锁
- 乐观锁 悲观锁
- 乐观锁悲观锁
- 乐观锁悲观锁
- 乐观锁、悲观锁
- 分享一个气泡提示框:JS+CSS练习
- bootstrap输入提示的使用及格式
- SDJZU 摆积木
- 《Linux内核设计与实现》学习笔记(01)
- 提高代码可读性的注释技巧
- 悲观锁、乐观锁、行级锁、表级锁
- PHP程序员面试中经常被提问的问题
- (转载)Win7系统下载速度很快,上传速度超慢的解决
- 11个UI设计秘诀
- 过MemCached
- 构造函数经典面试题
- 100元买鸡算法题 php程序员面试题
- 登录跳转
- hosts更新 2013.8.17