MySQL 事务隔离级别

拼搏现实的明天。 2022-09-04 03:42 385阅读 0赞

MySQL 设置事务隔离级别

在这里插入图片描述

查看事务隔离级别

查看全局事务隔离级别

  1. mysql> SELECT @@GLOBAL.transaction_isolation;
  2. +--------------------------------+
  3. | @@GLOBAL.transaction_isolation |
  4. +--------------------------------+
  5. | REPEATABLE-READ |
  6. +--------------------------------+
  7. 1 row in set (0.00 sec)

查看当前会话事务隔离级别

  1. mysql> SELECT @@SESSION.transaction_isolation;
  2. +---------------------------------+
  3. | @@SESSION.transaction_isolation |
  4. +---------------------------------+
  5. | REPEATABLE-READ |
  6. +---------------------------------+
  7. 1 row in set (0.00 sec)

设置事务隔离级别































级别 代码 特点
读未提交 READ-UNCOMMITTED 允许脏读取,但不允许更新丢失。如果一个事务已经开始写数据,则另外一个事务则不允许同时进行写操作,但允许其他事务读此行数据。该隔离级别可以通过“排他写锁”实现。
读提交 READ-COMMITTED 允许不可重复读取,但不允许脏读取。这可以通过“瞬间共享读锁”和“排他写锁”实现。读取数据的事务允许其他事务继续访问该行数据,但是未提交的写事务将会禁止其他事务访问该行。
可重复读取 REPEATABLE-READ 禁止不可重复读取和脏读取,但是有时可能出现幻读数据。这可以通过“共享读锁”和“排他写锁”实现。读取数据的事务将会禁止写事务(但允许读事务),写事务则禁止任何其他事务。
序列化 SERIALIZABLE 提供严格的事务隔离。它要求事务序列化执行,事务只能一个接着一个地执行,不能并发执行。仅仅通过“行级锁”是无法实现事务序列化的,必须通过其他机制保证新插入的数据不会被刚执行查询操作的事务访问到。

​ 隔离级别越高,越能保证数据的完整性和一致性,但是对并发性能的影响也越大。对于多数应用程序,可以优先考虑把数据库系统的隔离级别设为Read Committed。它能够避免脏读取,而且具有较好的并发性能。尽管它会导致不可重复读、幻读和第二类丢失更新这些并发问题,在可能出现这类问题的个别场合,可以由应用程序采用悲观锁或乐观锁来控制。

使用GLOBAL关键字

  • 该声明适用于所有后续会话。
  • 现有会话不受影响。

    mysql> SET GLOBAL transaction_isolation = ‘READ-COMMITTED’;
    Query OK, 0 rows affected (0.02 sec)

    mysql> SELECT @@GLOBAL.transaction_isolation;
    +————————————————+
    | @@GLOBAL.transaction_isolation |
    +————————————————+
    | READ-COMMITTED |
    +————————————————+
    1 row in set (0.00 sec)

使用SESSION关键字

  • 该语句适用于当前会话中执行的所有后续事务。
  • 该语句在事务中是允许的,但不影响当前正在进行的事务。
  • 如果在事务之间执行,该语句将覆盖任何先前设置命名特征的下一个事务值的语句。

    mysql> SET SESSION transaction_isolation = ‘READ-UNCOMMITTED’;
    Query OK, 0 rows affected (0.00 sec)

    mysql> SELECT @@SESSION.transaction_isolation;
    +————————————————-+
    | @@SESSION.transaction_isolation |
    +————————————————-+
    | READ-UNCOMMITTED |
    +————————————————-+
    1 row in set (0.00 sec)

没有任何SESSIONor GLOBAL关键字

  • 该语句仅适用于会话中执行的下一个单个事务。
  • 后续事务恢复使用命名特征的会话值。
  • 交易中不允许使用以下语句:

    1. mysql> START TRANSACTION;
    2. Query OK, 0 rows affected (0.02 sec)
    3. mysql> SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
    4. ERROR 1568 (25001): Transaction characteristics can't be changed
    5. while a transaction is in progress

    mysql> SET transaction_isolation = ‘SERIALIZABLE’;
    Query OK, 0 rows affected (0.02 sec)

    mysql> SELECT @@transaction_isolation;
    +————————————-+
    | @@transaction_isolation |
    +————————————-+
    | SERIALIZABLE |
    +————————————-+
    1 row in set (0.00 sec)

发表评论

表情:
评论列表 (有 0 条评论,385人围观)

还没有评论,来说两句吧...

相关阅读

    相关 MySQL事务-隔离级别

    事务的并发问题 1. 脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据 2. 不可重复读:事务 A 多次读取同一数据,事务 B 在事务A

    相关 MySQL事务隔离级别

    数据库是多线程并发访问的,所以很容易出现多个线程同时同时开启事务的情况,这样就会出现脏读、重复读及幻读的情况,通过为事物设置隔离级别,来避免这种情况的发生。 在 MySQL