老生常谈,MySQL事务隔离级别

在 MySQL 关系型数据库中,事务隔离级别主要有以下四种:

1)读未提交(READ UNCOMMITTED):

这是最低的隔离级别,在该级别下,一个事务可以看到另一个事务尚未提交的数据修改。这可能会导致脏读问题,即读取到其他事务未提交的数据;

2)读已提交(READ COMMITTED):

在这个级别下,一个事务只能看到已经提交的其他事务所做的修改。这可以避免脏读问题,但是可能会引发不可重复读问题,即在同一个事务中,相同的查询可能返回不同的结果;

3)可重复读(REPEATABLE READ):

在这个级别下,确保在一个事务中的多个查询返回的结果是一致的。这可以避免不可重复读问题,但是可能会引发幻读问题,即在同一个事务中,多次查询可能返回不同数量的行(MySQL 默认的隔离级别);

4)串行化(SERIALIZABLE):

这是最高的隔离级别,在这个级别下,事务串行执行,即每个事务都会等待前一个事务执行完毕才会开始执行。这可以避免所有的并发问题,但是会大大降低并发性能。

这些问题相信大家也都很了解了,必学必问,但是不可重复读与幻读有什么区别呢???

相关推荐
莳花微语15 分钟前
使用MyCAT实现分布式MySQL双主架构
分布式·mysql·架构
he2581921 分钟前
centOS 7.9 安装JDK MYSQL
java·mysql·centos
夜泉_ly3 小时前
MySQL -安装与初识
数据库·mysql
月光水岸New6 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
我爱松子鱼6 小时前
mysql之规则优化器RBO
数据库·mysql
人间打气筒(Ada)8 小时前
MySQL主从架构
服务器·数据库·mysql
和道一文字yyds8 小时前
MySQL 中的索引数量是否越多越好?为什么?如何使用 MySQL 的 EXPLAIN 语句进行查询分析?MySQL 中如何进行 SQL 调优?
数据库·sql·mysql
哆木11 小时前
排查生产sql查询缓慢
数据库·sql·mysql
book012112 小时前
MySql数据库运维学习笔记
运维·数据库·mysql
纠结哥_Shrek12 小时前
Oracle和Mysql的区别
数据库·mysql·oracle