事务

本文深入解析了数据库事务的四大特性:原子性、一致性、隔离性和持久性,并详细阐述了事务并发操作可能引发的脏读、不可重复读和虚读等问题,以及不同隔离级别对这些问题的处理方式。

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

一.事务的四大特性:
原子性: 事务中的所有操作都是不可分割的原子操作,事务的执行,要么全部成功,要么全部失败。
一致性:事务执行后,数据库状态与其它业务规则保持一致。如转账业务,无论事务执行成功与否,参与转账的两个账号余额之和应该是不变的。
隔离性:在并发操作中,多个事务需要隔离开分别执行。
持久性:在事务执行完毕之后,数据库中的数据无论在什么情况下都不会发生改变。
注意:若没有隔离性则会引发一系列的问题(脏读,不可重复读,虚读)
二.事务的并发读问题:
脏读:一个事务读到另外一个事务的未提交数据。
不可重复读:两次读取的结果不一致(由于在事务进行第一次读取后,另外一个事务对表中的数据进行修改)。
虚读:读到另一事务已提交数据(对表中的两次查询结果不一致,由于在一个事务第一次读取后,另外一个事务向表中增加记录)。
三.隔离级别:
1.SERIALIZABLE(串行化)三种读问题都能处理
2.REPEATABLE READ(可重复读)脏读、不可重复读,不能处理幻读(MySQL默认隔离级别)
3.READ COMMITTED(读已提交数据)只能处理脏读,不能处理不可重复读和幻读。(Oracle默认隔离级别)
4.READ UNCOMMITTED(读未提交数据)啥也不处理!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值