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


     

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

    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

    如果用表级锁,其他客户将不能进行查询操作,因此开发中记得用行级锁

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

    行级锁,一般是指排它锁,即被锁定行不可进行修改,删除,只可以被其他会话select。行级锁之前需要先加表结构共享锁

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

  • 相关阅读:
    AtCoder Grand Contest 019
    upd 2020.10.31
    ubuntu 自动配置脚本
    linux下gcc、g++不同版本的安装和切换
    fixes for 100% disk usage on Windows 10
    简单聊聊VisualStudio的断点调试
    运算符重载
    设计模式之桥接模式
    使用C#进行数据库增删改查ADO.NET(三)
    使用C#进行数据库增删改查ADO.NET(二)
  • 原文地址:https://www.cnblogs.com/qunxiadexiaoxiangjiao/p/9592494.html
Copyright © 2020-2023  润新知