zoukankan      html  css  js  c++  java
  • 数据库锁

    假设有个表单products ,里面有id 跟name 二个栏位,id 是主键。
    例1: (明确指定主键,并且有此数据,row lock)

    SELECT * FROM products WHERE id='3' FOR UPDATE;

    例2: (明确指定主键,若查无此数据,无lock)

    SELECT * FROM products WHERE id='-1' FOR UPDATE;

    例2: (无主键,table lock)

    SELECT * FROM products WHERE name='Mouse' FOR UPDATE;

    例3: (主键不明确,table lock)

    SELECT * FROM products WHERE id<>'3' FOR UPDATE;

    例4: (主键不明确,table lock)

    SELECT * FROM products WHERE id LIKE '3' FOR UPDATE;


    乐观所和悲观锁策略
    悲观锁:在读取数据时锁住那几行,其他对这几行的更新需要等到悲观锁结束时才能继续 。
    乐观所:读取数据时不锁,更新时检查是否数据已经被更新过,如果是则取消当前更新,一般在悲观锁的等待时间过长而不能接受时我们才会选择乐观锁。

  • 相关阅读:
    成绩
    多态与异常处理
    大道至简终结版
    继承与接口
    大道至简之编程到工程
    数组元素相加
    数组元素必须具有相同的数据类型?
    大道至简之失败的过程也是过程
    作业
    感想之流于形式的沟通
  • 原文地址:https://www.cnblogs.com/suneryong/p/9001607.html
Copyright © 2011-2022 走看看