• mysql事务隔离级别


    SQL标准定义了4种隔离级别,

    低级别的隔离级别一般支持更高的并发处理,并拥有更低的系统开销

    但是低级别的隔离级别,会让各级别之间干扰会更大一些

     

    事务隔离级别有四种

    1.read Uncommitted(读取未提交内容)

     

    (1)首先,修改隔离级别

            set tx_isolation='READ-UNCOMMITTED';
            select @@tx_isolation;
    (2)事务A:
            create table abc (name char(20),nianling int(3));

             insert into abc values ('a',20);

            insert into abc values ('b',18);

          
          启动一个事务

            begin;

            select * from abc;
            +------+----------+
            | name | nianling |
            +------+----------+
            | a    |       20    |
            | b    |       18    |
            +------+----------+
            

    (3)事务B  我们在开启一个xshell 登录到数据库后,在开启一个事务,执行完事务后, 不提交

        mysql> begin;

        mysql> select * from abc;

    +------+----------+

    | name | nianling |

    +------+----------+

    | a    |     20   |

    | b    |     18   |

    +------+----------+

        mysql> update abc set nianling=25 where name='a';

        我们更改abc的内容,但是不提交

     

    (4)在事务A上查看事务B 的更改。我们是能看到事务B的内容的。

    mysql> select * from abc;

    +------+----------+

    | name | nianling |

    +------+----------+

    | a    |       25 |

    | b    |       18 |

    +------+----------+

     

    即使在事务B上回滚,在A上也可以B上回滚后的内容。

    即使B提交了事务,A事务也可以看到提交后的内容。

     

     

     

    read Committed(读取提交内容)

        repeatable read(可重读)

        serializable(可串行化)

     这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行。InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题。

  • 相关阅读:
    pandas:由列层次化索引延伸的一些思考
    机器学习中的异常检测手段
    GBDT+LR算法解析及Python实现
    模型性能提升操作
    /usr/bin/python: can't decompress data; zlib not available 的异常处理
    FM算法解析及Python实现
    vue项目中的iview如何验证for循环的输入框、日期选择框,及表单回填验证不通过问题
    JavaScript的数组方法(array)
    Js中toFixed()方法保留小数不精准的问题
    vscode中iview的</Col>标签报错问题
  • 原文地址:https://www.cnblogs.com/pangbing/p/6535091.html
Copyright © 2020-2023  润新知