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

更新丢失:新改的覆盖先改的,开发中有三种方法解决css

1、将事务级别提升到最高级别TRANSACTION_SERIALIZABLEhtml

操做双方都要提高级别;查询使用共享锁;更新使用更新锁;一方查询,一方更新,共享锁和更新锁会冲突;当双方更新锁,出现死锁,程序会自动回滚一方操做,从而避免更新丢失mysql

2、悲观锁(加的是表级锁)sql

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

3、乐观锁spa

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

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

另外一方操做同一个版本号,则不能更新数据索引

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

若是更新多,查询少,用悲观锁;反之,乐观锁

表级锁,where用的是非主键

行级锁,where用主键通常是id

若是用表级锁,其余客户将不能进行查询操做,所以开发中记得用行级锁

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

行级锁,通常是指排它锁,即被锁定行不可进行修改,删除,只能够被其余会话select。行级锁以前须要先加表结构共享锁

表级锁,通常是指表结构共享锁锁,是不可对该表执行DDL操做,但对DML操做都不限制。
行级锁以前须要先加表结构共享锁

相关文章
相关标签/搜索