zoukankan      html  css  js  c++  java
  • 事务的四个隔离级别

    数据库中隔离级别的操作

    • 设置隔离级别:set tx_isolation = 'READ-UNCOMMITTED'
    • 查看隔离级别:select @@tx_isolation

    一、Read Uncommitted -- 读取未提交内容

    • 一个事务可以查看到未提交的内容
    • 常产生脏读问题(脏读:读取到其他事务未提交(执行)的内容)
      对同一数据表开启A、B两个事务(A、B事务交叉) start transaction
      A事务只查询数据表中内容,B事务做增删改操作但不commit(提交)
      A事务依旧可以查询到表中的数据改变(查询到未提交的内容--脏读)

    二、Read Committed -- 读取提交内容

    • 一个事务只能查看已提交的内容
    • 常产生不可重复读的问题(不可重复读:同一事务中执行相同的select语句得到不同的结果)
      对同一数据表开启A、B两个事务(A、B事务交叉) start transaction
      A事务只查询数据表中内容,B事务做增删改操作但不commit(提交)
      A事务查询不到表中的数据改变的内容
      B事务提交
      A查到的数据改变(A两次查询,产生不同的结果--不可重复读)

    三、Repeatable Read -- 可重读

    • 同一事务的多个实例并发读取数据时得到同一结果
    • MySQL的默认事务隔离级别
    • 常产生幻读问题(幻读:多次读取时产生不同结果(幻影行))
      对同一数据表开启A、B两个事务(A、B事务交叉) start transaction
      A事务只查询数据表中内容,B事务做增删改操作但不commit(提交)
      A事务查询不到表中的数据改变的内容
      B事务提交
      A事务查询不到表中的数据改变的内容
      A提交
      A可查询到表中数据的改变

    四、Serializable -- 可串行化

    • 最高隔离级别
    • 给事务加上共享锁,同时只能有一个事务操作,解决幻读问题
    • 会导致大量超时和锁竞争问题
      开启A事务
      开启B事务时无法增删该操作
  • 相关阅读:
    获取非行间样式
    获取非行间样式
    prompt 方法显示输入对话框
    comfirm 方法显示对话框
    移动端页面常见问题及解决方案
    原生js怎样获取后台端口数据
    canvas描绘渐变的矩形
    cookie 的增加,销毁,读取
    canvas 绘制图形
    数组的排序,去重复
  • 原文地址:https://www.cnblogs.com/QX-Tang/p/11516567.html
Copyright © 2011-2022 走看看