在 MySQL 中,事务隔离级别用于控制事务之间的可见性和并发行为。设置合适的隔离级别可以平衡数据一致性和系统性能。MySQL 支持四种标准的事务隔离级别:
READ UNCOMMITTED:最低隔离级别,允许读取未提交的数据(脏读)。 READ COMMITTED:只能读取已提交的数据,避免脏读。 REPEATABLE READ:确保在同一事务中多次读取同一数据结果一致(MySQL 默认级别)。 SERIALIZABLE:最高隔离级别,完全串行化事务执行,避免幻读。查看当前隔离级别
SELECT @@transaction_isolation;这条命令会显示当前会话或全局的事务隔离级别。
设置事务隔离级别
可以在两个层面设置隔离级别:全局级别和当前会话级别。
1. 设置全局隔离级别
SET GLOBAL transaction_isolation = 'REPEATABLE-READ';这会影响之后所有新建立的会话,但不会影响当前已存在的会话。
2. 设置当前会话隔离级别
SET SESSION transaction_isolation = 'READ-COMMITTED';这只会影响当前客户端连接的事务行为。
3. 在事务中临时设置
也可以在开始事务时指定隔离级别:
START TRANSACTION;SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
-- 执行 SQL 语句
COMMIT;
注意:SET TRANSACTION 必须在 START TRANSACTION 之后、第一条数据操作语句之前调用。
常见配置示例
设为读已提交:SET SESSION transaction_isolation = 'READ-COMMITTED'; 设为可重复读:SET GLOBAL transaction_isolation = 'REPEATABLE-READ'; 设为串行化:SET SESSION transaction_isolation = 'SERIALIZABLE';修改后建议再次使用 SELECT @@transaction_isolation; 确认是否生效。
基本上就这些。根据应用对一致性与并发的要求选择合适级别即可。生产环境通常保持默认 REPEATABLE READ,特殊场景如高并发读可考虑 READ COMMITTED。
