美文网首页程序员
查询mysql事务隔离级别

查询mysql事务隔离级别

作者: Cocoonshu粽子 | 来源:发表于2017-03-08 10:16 被阅读194次

    1.查看当前会话隔离级别

    select @@tx_isolation;

    2.查看系统当前隔离级别

    select @@global.tx_isolation;

    3.设置当前会话隔离级别

    set session transaction isolatin level repeatable read;

    4.设置系统当前隔离级别

    set global transaction isolation level repeatable read;

    5.命令行,开始事务时

    set autocommit=off 或者 start transaction

    关于隔离级别的理解

    1.read uncommitted

    可以读取未提交的数据(脏读),举个例子:我在事务里面修改一个字段值,但是因为各种原因没有提交(实际没有修改),但是其他事务读到了我要修改的值。

    2.read committed

    读取提交的数据。但是,可能多次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,可以写。举个例子:我在账户扣钱事务先查一个遍账户余额,发现我的账户余额足够本次扣除,再次执行扣款的修改语句,这是我的账户又被其他消费了一笔,余额不足这次扣除了,告诉我不能执行这次扣除了。

    3.repeatable read(MySQL默认隔离级别)

    可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。采用多版本并发控制(MVCC)机制解决幻读问题。

    4.serializable

    可读,不可写。像java中的锁,写数据必须等待另一个事务结束,线性执行。

    相关文章

      网友评论

        本文标题:查询mysql事务隔离级别

        本文链接:https://www.haomeiwen.com/subject/xufbgttx.html