zoukankan      html  css  js  c++  java
  • 数据库隔离 脏读 幻读与不可重复读

    一、隔离级别与现象

    数据库隔离有4个级别

    read uncomitted ,未授权读取

    read committed ,授权读取

    repeatable read , 可重复读

    serializable ,串行化

    可能产生的不一致的现象有3种

    脏读

    不可重复读

    幻读

    二、3种现象

      脏读,就是读了脏数据;另一个事务修改了数据但未提交,我们读到了这个未提交的数据即脏数据,这种现象就是脏读;

    举个栗子,balance字段值为100,另一个事务修改为200,未提交的时候我们读到了200,接着那个事务回滚了,实际值应该是100,但我们读的是200;

      不可重复读,就是对于一个数据,我重复读的时候它的值发生了改变;即两次读取之间被另一个事务进行了修改;

    再举个栗子,我读到balance字段值为100,我做了判断(比如是否大于0),然后我再次读的时候它变成了200; 对于100这个值我没有重复读到,即发生了不可重复读;

      幻读,就是再次读取时发现了新的记录或少了记录,以为出现了幻觉;

    最后一颗栗子,我读数据的时候没有balance字段,我要新增balance为0时,提示我存在这个字段了;我第二次读的时候 多了这条记录,我以为第一次读出现了幻觉;

    大多数场景是我第一次读完后(可能是修改了某条数据后再读的),锁定了我读的那一条数据,但另一个事务改了这张表的其它数据,我第二次读的时候以为第一次读出现了幻觉(可能第一次修改了全表,另一个事务只改了一条数据,我以为我没成功修改那条数据);

    三、隔离级别

      脏读 不可重复读 幻读
    Read uncommitted 可能发生  可能发生 可能发生
    Read committed   可能发生 可能发生
    Repeatable read     可能发生
    Repeatable read      
  • 相关阅读:
    C#资源释放方法实例分析
    c#中在一个窗体中触发另一个窗体的事件
    C#定时器的用法
    C# 类的析构函数和释放函数
    C# 定时执行,文件占用
    C#多线程与异步
    Newtonsoft中JArray 转成list<object>
    C#中Dictionary的用法
    C# 解析Json文件(使用NewtonJson库)
    mysql无法远程连接10038错误的坑(阿里云ecs)
  • 原文地址:https://www.cnblogs.com/chenhao0302/p/9166100.html
Copyright © 2011-2022 走看看