事务的隔离级别

事务的隔离级别是数据库管理系统(DBMS)中用于控制并发事务之间如何相互影响的机制。不同的隔离级别提供了不同程度的并发性和数据一致性保证。下面将讲解四种主要的事务隔离级别,按低到高开始说起。

一、读未提交(READ_UNCOMMITTED):

1.最低的隔离级别。

2.允许事务读取另一个事务尚未提交的数据。这可能导致读取到不一致或"脏"的数据,因为其他事务可能会回滚其更改。

3.由于没有锁机制或同步操作来防止脏读,因此该级别可能会提高并发性能,但数据一致性无法得到保证。

4.在实际应用中,很少使用此隔离级别,因为它可能导致数据错误。

事务读取:不加锁

事务写入:加写锁

解决问题:脏写

存在问题:脏读,不可重复读、幻读。

二、读提交(READ_COMMITTED):

1.允许事务读取另一个事务已经提交的数据。

2.防止了脏读,因为每个事务只能看到已经提交的更改。

3.但是,它允许不可重复读和幻读。即,在同一个事务中,如果另一个事务对同一数据进行了修改或插入新数据,那么该事务在后续读取时可能会得到不同的结果。

4.这是一个常用的隔离级别,因为它提供了相对较好的数据一致性和并发性能之间的平衡。

事务读取:加读锁(每次select完成都会释放读锁)

事务写入:加写锁

解决问题:脏读

存在问题:不可重复读、幻读

三、可重复读(REPEATABLE_READ):

1.保证在同一个事务中多次读取同一数据时,得到的结果是一致的。

2.防止了脏读和不可重复读。但是,它仍然可能允许幻读(取决于具体的数据库实现)。

3.在某些数据库系统中,如MySQL的InnoDB存储引擎,通过使用间隙锁(gap locks)等技术来防止幻读,从而将可重复读提升到了更高的数据一致性水平。

4.这个隔离级别在需要确保数据一致性但又不想引入过多并发开销的场景中很有用。

事务读取:加读锁(每次select完不会释放锁,而是事务结束后才释放)(如果是Mysql的innodb还会加间隙锁)

事务写入:加写锁

解决问题:脏写、脏读、不可重复读、幻读(如果是innodb则已解决)

存在问题:幻读(如果是Mysql的innodb则不存在)。

四、串行化(SERIALIZABLE):

1.最高的隔离级别。

2.通过强制事务按顺序执行来防止脏读、不可重复读和幻读。

3.它提供了最强的数据一致性保证,但可能会显著降低并发性能,因为事务需要等待其他事务完成才能继续执行。

4.在可串行化级别下,数据库系统通常会使用锁机制(如表级锁或行级锁)或时间戳排序来确保事务的串行化执行。

5.这个隔离级别在需要高度数据一致性的场景中很有用,但可能会引入较大的性能开销。

相关推荐
用户47949283569156 小时前
性能提升 4000%!我是如何解决 运营看板 不能跨库&跨库查询慢这个难题的
数据库·后端·postgresql
电商API&Tina6 小时前
跨境电商 API 对接指南:亚马逊 + 速卖通接口调用全流程
大数据·服务器·数据库·python·算法·json·图搜索算法
robinson19887 小时前
验证崖山数据库标量子查询是否带有CACHE功能
数据库·oracle·cache·自定义函数·崖山·标量子查询
老华带你飞7 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
SelectDB7 小时前
5 倍性能提升,Apache Doris TopN 全局优化详解|Deep Dive
数据库·apache
JIngJaneIL8 小时前
基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
陈平安安8 小时前
设计一个秒杀功能
java·数据库·sql
isNotNullX8 小时前
数据处理的流程是什么?如何进行数据预处理?
数据库·数据资产管理·数据处理·企业数字化
TAEHENGV8 小时前
基本设置模块 Cordova 与 OpenHarmony 混合开发实战
android·java·数据库
Leo1878 小时前
MySQL 回表(Back to Table)详解
数据库·mysql