MySQL 事务隔离级别
MySQL 设置事务隔离级别
查看事务隔离级别
查看全局事务隔离级别
mysql> SELECT @@GLOBAL.transaction_isolation;
+--------------------------------+
| @@GLOBAL.transaction_isolation |
+--------------------------------+
| REPEATABLE-READ |
+--------------------------------+
1 row in set (0.00 sec)
查看当前会话事务隔离级别
mysql> SELECT @@SESSION.transaction_isolation;
+---------------------------------+
| @@SESSION.transaction_isolation |
+---------------------------------+
| REPEATABLE-READ |
+---------------------------------+
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)
没有任何SESSION
or GLOBAL
关键字
- 该语句仅适用于会话中执行的下一个单个事务。
- 后续事务恢复使用命名特征的会话值。
交易中不允许使用以下语句:
mysql> START TRANSACTION;
Query OK, 0 rows affected (0.02 sec)
mysql> SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
ERROR 1568 (25001): Transaction characteristics can't be changed
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)
还没有评论,来说两句吧...