事务特性及脏读、不可重复读、幻读(虚读)

本文详细解释了数据库事务的基本概念及ACID特性:原子性、一致性、隔离性和持久性,并探讨了不同隔离级别下可能产生的脏读、不可重复读及幻读等问题。

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

事务是指逻辑上的一组操作,这组操作要么全部成功,要么全部失败。

事务的特性(ACID):

原子性(A):事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。

一致性(C):事务前后数据的完整性必须保持一致。例:A:200,B:200,A、B之间无论怎么交换,最终都要保证和是400。

隔离性(I):多个用户并发访问数据库时,一个用户的事务不能被其他用户的事务所干扰,多个并发事务之间数据要相互隔离。如果不考虑隔离性,会引发安全问题如下:脏读不可重复读幻读(虚读)。

脏读:一个事务读取了另一个事务改写但还未提交的数据,如果这些数据被回滚,则读到的数据是无效的。

不可重复读:在同一事务中,多次读取同一数据返回的结果有所不同,读到了之前的数据后又读到了其他事务已经提交的更新的数据。

幻读(虚读):一个事务读取了几行记录后,另一个事务插入(insert)一些记录幻读就发生了。再后来的查询中,第一个事务就会发现有些原来没有的记录。

因此需要设置事务隔离级别(四种)。


如果隔离级别设置成DEFAULT,那么底层数据库用什么,DEFAULT就表示什么隔离级别。

Mysql默认采用REPEATABLE_READ隔离级别。

Oracle默认采用READ_COMMITTED隔离级别。

持久性(D):一个事务一旦被提交,他对数据库中数据的改变是永久性的,即使数据库发生故障也不应该对其有影响。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值