• mysql 隔离级别


    1 事务就是一组数据库操作,要不全部都成功,要不全部都失败。
    2 事务包含ACID (Atomicity Consistency Isolation Durability)。
    3 数据库上有多个事务同时执行的时候,就有可能造成 脏读(dity Read)不可重复读(no-repeatable read)幻读(phantom read),因此就有了事务的隔离级别。
    4 sql 的标准隔离级别有:
    4.1 读未提交(read uncommit): 一个事务还没提交,它做出的改变就能被别的事务看到。
    4.2 读提交(read commit): 一个事务提交后,它做出的变更才能被别 的事务看到。
    4.3 可重复读(repeatable read): 一个事务在执行中看到的数据,总是和这个事务启动的时候,看到的数据是一致的。
    当然在可重复读的隔离级别下,事务执行过程中数据的改变对其他事务时不可见的。
    4.4 串行化(serializable): 对于同一行记录,写会加写锁,读会加读锁。别的事物要访问这条记录,只能等当前事务提交之后才能访问 这条记录。

    mysql 展示 当前变量的事务 show variables like 'transaction_isolation';

    5 事务的实现原理
    mysql 在更新每条记录的时候,都会同时创建一条回滚操作(read-views)。记录上的最新值可以通过read-views回滚到之前的值。

    6 你可以在 information_schema 库的 innodb_trx 这个表中查询长事务,比如下面这个语句,用于查找持续时间超过 60s 的事务。
    select * from information_schema.innodb_trx where TIME_TO_SEC(timediff(now(),trx_started))>60

  • 相关阅读:
    ADC推荐:测量Flash的视频消费行为 (转载)
    9.7Go之函数之递归函数
    9.8线性表之单链表
    9.7线性表之顺序表
    9.7顺序表之增、删、改、查
    9.8Go之函数之计算执行时间
    9.8Go之函数之宕机(panic)
    9.9Go语言内存缓存
    9.7Go之函数之处理RuntimeError
    9.7Go之函数之defer(延迟执行语句)
  • 原文地址:https://www.cnblogs.com/prader6/p/14950146.html
Copyright © 2020-2023  润新知