事务的隔离级别

事务的隔离级别是数据库管理系统(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.这个隔离级别在需要高度数据一致性的场景中很有用,但可能会引入较大的性能开销。

相关推荐
老华带你飞1 小时前
口腔助手|口腔挂号预约小程序|基于微信小程序的口腔门诊预约系统的设计与实现(源码+数据库+文档)
java·数据库·微信小程序·小程序·论文·毕设·口腔小程序
hqxstudying1 小时前
J2EE模式---服务层模式
java·数据库·后端·spring·oracle·java-ee
Yu_Lijing1 小时前
MySQL进阶学习与初阶复习第四天
数据库·学习·mysql
大熊程序猿1 小时前
net8.0一键创建支持(Orm-Sqlite-MySql-SqlServer)
数据库·mysql·sqlite
-SGlow-10 小时前
MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)
linux·运维·服务器·数据库·mysql
明月56611 小时前
Oracle 误删数据恢复
数据库·oracle
♡喜欢做梦12 小时前
【MySQL】深入浅出事务:保证数据一致性的核心武器
数据库·mysql
遇见你的雩风12 小时前
MySQL的认识与基本操作
数据库·mysql
dblens 数据库管理和开发工具13 小时前
MySQL新增字段DDL:锁表全解析、避坑指南与实战案例
数据库·mysql·dblens·dblens mysql·数据库连接管理
weixin_4196583113 小时前
MySQL的基础操作
数据库·mysql