mysql isolation level_数据库隔离级 ( Isolation level )_MySQL

本文介绍了MySQL数据库的四种隔离级别:Serializable、Repeatable Read、Read Committed和Read Uncommitted,详细阐述了每种级别的特点,如幻读、不可重复读和脏读问题,并提供了MySQL设置事务隔离级别的语法。通过理解这些概念,有助于更好地管理和理解数据库事务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

bitsCN.com

专业术语:phantom reads[幻读]- Repeatable Reads Level:事务A的两次范围查询之间,事物B在范围内插入了数据,导致事务A的两次查询结果不一致(因为范围锁range-locks)

non-repeatable reads[重复读取不一致]- Read Committed Level:事务A对某一行进行两次查询,在这两次查询之间,事物B对这一行的数据进行了修改,导致事务A的两次查询结果不一致

dirty reads[脏读]- Read Uncommitted Level:事务A对某一行进行两次查询,在这两次查询之间,事物B对这一行的数据进行了修改,但是未提交而是回滚,导致事务A的第二次查询读取了错误的数据

隔离级:

Serializable [串行]

This is the highest isolation level.

With a lock-based concurrency control DBMS implementation, serializability requires read and write locks (acquired on selected data) to be released at the end of the transaction. Also range-locks must be acquired when a SELECT query uses a ranged WHERE clause, especially to avoid the phantom reads phenomenon (see below).

When using non-lock based concurrency control, no locks are acquired; however, if the system detects a write collision among several concurrent transactions, only one of them is allowed to commit. Seesnapshot isolation for more details on this topic.

Repeatable reads [重复读]

In this isolation level, a lock-based concurrency control DBMS implementation keeps read and write locks (acquired on selected data) until the end of the transaction. However, range-locks are not managed, so the phantom reads phenomenon can occur (see below).

Read committed [读提交]

In this isolation level, a lock-based concurrency control DBMS implementation keeps write locks (acquired on selected data) until the end of the transaction, but read locks are released as soon as theSELECT operation is performed (so the non-repeatable reads phenomenon can occur in this isolation level, as discussed below). As in the previous level, range-locks are not managed.

Read uncommitted [读未提交]

This is the lowest isolation level. In this level, dirty reads are allowed (see below), so one transaction may see not-yet-committed changes made by other transactions.

MySQL参数配置:SET [GLOBAL | SESSION] TRANSACTION ISOLATION LEVEL{ REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE}

感觉其实看懂了还是非常好理解的,只是不太好描述~

参考文献:

[wiki]:http://en.wikipedia.org/wiki/Isolation_(database_systems)

[MySQL]:http://dev.mysql.com/doc/refman/5.5/en/dynindex-isolevel.htmlbitsCN.com

f68f2add0b68e4f9810432fce46917b7.png

相关标签:查询 专业

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值