【转】脏读、不可重复读、幻读

本文详细介绍了数据库中事务并发可能引发的问题如脏读、不可重复读和幻觉读,以及通过锁机制来解决这些问题的方法,确保数据的一致性和完整性。

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

锁就是防止其他事务访问指定的资源的手段。锁是实现并发控制的主要方法,是多个用户能够同时操纵同一个数据库中的数据而不发生数据不一致现象的重要保障。 一般来说,锁可以防止脏读、不可重复读和幻觉读。

事务并发产生的问题:
脏读:一个事务读取到了另外一个事务没有提交的数据
事务1:更新一条数据
————->事务2:读取事务1更新的记录
事务1:调用commit进行提交

        ***此时事务2读取到的数据是保存在数据库内存中的数据,称为脏读。
        ***读到的数据为脏数据
        详细解释:
            脏读就是指:当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,
            另外一个事务也访问这个数据,然后使用了这个数据。因为这个数据是还没有提交的数据,那么另外一个
            事务读到的这个数据是脏数据,依据脏数据所做的操作可能是不正确的。

    不可重复读:在同一事务中,两次读取同一数据,得到内容不同
        事务1:查询一条记录
                        -------------->事务2:更新事务1查询的记录
                        -------------->事务2:调用commit进行提交
        事务1:再次查询上次的记录

        ***此时事务1对同一数据查询了两次,可得到的内容不同,称为不可重复读

    幻读:同一事务中,用同样的操作读取两次,得到的记录数不相同
        事务1:查询表中所有记录
                          -------------->事务2:插入一条记录
                          -------------->事务2:调用commit进行提交
        事务1:再次查询表中所有记录

        ***此时事务1两次查询到的记录是不一样的,称为幻读.

转:http://blog.youkuaiyun.com/gaoshan_820822/article/details/4582561

### 、可重复不可重复的概念及区别 #### 1. (Dirty Read) 是指一个事务取了另一个事务未提交的数据。这种情况会导致取到的数据可能是无效的或错误的,因为另一个事务可能会回滚其更改。在 SQL 标准中,`READ UNCOMMITTED` 隔离级别允许[^1]。 #### 2. 不可重复 (Non-Repeatable Read) 不可重复是指在一个事务内多次取同一数据时,由于其他事务对该数据进行了修改并提交,导致取结果不一致。这种问题在 `READ COMMITTED` 隔离级别下可能发生,因为它虽然防止了,但不能保证多次取的一致性[^2]。 #### 3. (Phantom Read) 是指一个事务在执行相同查询时,由于其他事务插入或删除了数据,导致两次查询的结果集不同。不可重复的区别在于,涉及的是新插入或删除的行,而不是现有行的修改。在 `REPEATABLE READ` 隔离级别下,虽然解决了不可重复问题,但仍可能出现[^3]。 #### 4. 可重复 (Repeatable Read) 可重复是指在一个事务内多次取同一数据时,结果始终保持一致。这是因为在该隔离级别下,事务开始后取的数据会被锁定,防止其他事务对其进行修改。`REPEATABLE READ` 解决了不可重复问题,但在某些情况下仍可能遇到[^4]。 ### 数据库事务隔离级别 SQL 标准定义了四种隔离级别,每种级别解决不同的事务隔离问题: 1. **READ UNCOMMITTED**:最低的隔离级别,允许不可重复。 2. **READ COMMITTED**:解决了问题,但仍可能出现不可重复。 3. **REPEATABLE READ**:解决了不可重复问题,但仍可能出现。 4. **SERIALIZABLE**:最高的隔离级别,解决了不可重复问题,但性能开销较大。 ### 示例代码 以下是一个简单的事务隔离级别设置示例(以 MySQL 为例): ```sql -- 设置事务隔离级别为 REPEATABLE READ SET TRANSACTION ISOLATION LEVEL REPEATABLE READ; -- 开始事务 START TRANSACTION; -- 查询数据 SELECT * FROM table_name WHERE condition; -- 提交事务 COMMIT; ``` ### 锁机制 InnoDB 存储引擎通过锁机制实现事务隔离。常见的锁类型包括共享锁(S锁)和排他锁(X锁)。共享锁允许其他事务取被锁行,但禁止修改;排他锁则禁止其他事务取或修改被锁行。此外,InnoDB 的行级锁依赖于索引,若无索引可用,则会退化为表级锁,影响并发性能[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值