数据库操作隔离级别(isolation level)详解

本文详细解析了MySQL的repeatableread和Oracle的ReadCommited隔离级别,通过实例展示了更新丢失、脏读、非重复读和幻像等现象,并对比了两者的默认设置。深入探讨了事务隔离级别的重要性和应用场景。

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

四个隔离级别
未提交读(read uncommitted)
提交读(read committed)
重复读(repeatabe read)
序列化(seriaizabe)

通过一些现象 可以反映隔离级别效果。
更新丢失(ost update):当系统允许两个事务同时更新同一数据是,发生更新丢失。
脏读(dirty read):当一个事务读取另一个事务尚未提交的修改时,产生脏读。
非 重复读(nonrepeatabe read):同一查询在同一事务中多次进行,由于其他提交事务所做的修改或删除,每次返回不同的结果集,此时发生非重复读。(A transaction rereads
data it has previousy read and finds that another committed transaction has
modified or deeted the data. )
幻 像(phantom read):同一查询在同一事务中多次进行,由于其他提交事务所做的插入操作,每次返回不同的结果集,此时发生幻像读。(A transaction reexecutes a query returning a set of rows that satisfies a search condition and finds that another committed transaction has inserted additional rows that satisfy the condition. )
在这里插入图片描述
MySQL的默认事务隔离级别:
repeatable read

Oracle的默认隔离级别:
ReadCommited

Oracle ---- 事务隔离级别那些事儿

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值