事务的隔离级别

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

相关推荐
夜泉_ly3 小时前
MySQL -安装与初识
数据库·mysql
qq_529835354 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New6 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6756 小时前
数据库基础1
数据库
我爱松子鱼6 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo6 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser7 小时前
【SQL】多表查询案例
数据库·sql
Galeoto8 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)8 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231118 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql