MySQL 中的事务隔离级别有哪些?

news/2024/12/15 0:11:44/文章来源:https://www.cnblogs.com/eiffelzero/p/18607446

MySQL 中的事务隔离级别有哪些?

在 MySQL 中,事务隔离级别用于定义一个事务能看到其他事务未提交的数据的程度。MySQL 支持以下四种事务隔离级别,每种级别对并发操作的支持程度和一致性要求不同。隔离级别的设置通常通过 SET TRANSACTION ISOLATION LEVEL 语句来进行。


1. 读未提交(Read Uncommitted)

  • 定义:事务可以读取到其他事务未提交的数据,这意味着事务可以看到其他事务的 脏数据
  • 特性
    • 允许 脏读:一个事务可以读取另一个事务修改但尚未提交的数据。
    • 不保证事务数据的隔离性。
  • 影响
    • 脏读:读取未提交的数据可能导致数据不一致。
    • 提供最差的并发控制和一致性,性能较好,但可能引发严重的业务逻辑问题。

2. 读已提交(Read Committed)

  • 定义:事务只能读取到其他事务已经提交的数据。即使一个事务在执行过程中多次读取数据,也只能看到其他事务已经提交的数据。
  • 特性
    • 允许 脏读 被防止,但仍然允许 不可重复读
    • 每次读取数据时都会重新查询数据库,因此每次读取的结果可能不同。
  • 影响
    • 不可重复读:同一事务在两次读取之间可能会看到不同的数据。
    • 性能上比 读未提交 要好,但依然无法防止所有的并发问题。

3. 可重复读(Repeatable Read)

  • 定义:在事务开始后,事务内的所有查询都将读取到相同的数据,直到事务结束为止,保证了 不可重复读 的避免。
  • 特性
    • 允许 幻读,即事务执行期间,其他事务插入的行数据不会被当前事务看到。
    • 默认的事务隔离级别(对于 InnoDB 存储引擎而言)。
    • 保证了读取的数据一致性,每次读取相同数据时返回的结果相同。
  • 影响
    • 不可重复读 被解决,保证数据一致性。
    • 幻读 问题仍然存在,多个事务并发执行时,可能会插入新的数据行,导致查询结果不一致。

4. 串行化(Serializable)

  • 定义:事务完全隔离,即所有事务都按顺序串行执行,不允许其他事务并发执行。这是最严格的事务隔离级别。
  • 特性
    • 会强制事务 加锁,避免了 脏读不可重复读幻读
    • 通过强制事务之间的完全顺序执行来保证数据的一致性。
  • 影响
    • 解决所有并发问题(包括脏读、不可重复读和幻读)。
    • 性能极差,因为事务会被强制串行化执行,导致系统吞吐量显著下降。

总结

隔离级别 脏读 不可重复读 幻读
读未提交 允许 允许 允许
读已提交 不允许 允许 允许
可重复读 不允许 不允许 允许
串行化 不允许 不允许 不允许

选择合适的隔离级别

  • 在 MySQL 中选择合适的事务隔离级别是根据应用需求来定的。一般来说,高并发系统需要选择较低的隔离级别以提高性能(如 读已提交可重复读),但需要保证数据一致性;而对于数据一致性要求极高的场景,可能选择 串行化,尽管它的性能代价较高。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/852740.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自动续期的免费ssl证书_薅羊毛

自建的个人网站使用了阿里的ssl证书,以前有一年有限期,现在被改为3个月有限期,费时费力每次要续期,某猫总是喵呜喊着“打钱”。 经济不景气,只能想办法找免费方便的方案。 方案是:Lets Encrypt三个月免费证书 + certbot证书安装续期工具 + cron任务 1,安装certbot工具包…

Logi Options Plus精简安装

✨Logi Options Plus精简安装 Logi Options Plus经常会需要更新,如果不点开更新就会在Launchpad出现“罗技语音”、“罗技AI”的图标 可以更新但不想经常出现这些图标,影响本人完美的Launchpad布局了解到一个GitHub Repository:Logi Options Plus Mini https://github.com/Q…

Java线程命名问题解决

前言 网上冲浪时刷到线程池的文章,想想看自己好像还没在实际场景中设置过线程名称,小小研究一下。 研究过程 默认命名 创建的线程都会有自己的名字,如果不设置,程序会给线程默认的名字,如Thread-0 Thread t = new Thread(() -> {System.out.println(Thread.currentThre…

差分约束系统,2-SAT

一.差分约束 问题是给定x1,x2,……,xn,然后给定出若干限制 xi-xj<=c,然后求解/无解 xi-xj>=c可以转换成xj-xi<=-c; xi-xj=c,可以转换为xi-xj<=c,xi-xj>=c;最暴力的想法就是一开始给所有的变量都赋值为0,然后每次都暴力循环所有的限制,如果有限制不满足,直接改变…

update一下

近日自己做的饭

Linux挂载机械硬盘raid操作说明

1.查看磁盘的信息,确认磁盘名 一般可以根据磁盘的大小来确认是那个,如图所示,是 /dev/md127lsblk 2.将磁盘的文件类型转化为exts,注意该操作将删除该磁盘所有的数据!!!!mkfs.ext4 /dev/md127 3.挂在目录,如果不存在先创建目录,这里为 /source 挂在完成后使用 df -h查…

Mind(基础入门篇)

对于在基础入门中所学习知识点做一总结。附:完整笔记目录~ ps:本人小白,笔记均在个人理解基础上整理,若有错误欢迎指正! 七、Mind(基础入门篇)

《Django 5 By Example》阅读笔记:p543-p550

《Django 5 By Example》学习第 19 天,p543-p550 总结,总计 8 页。 一、技术总结 1.fixtures (1)定义 A fixture is a collection of files that contain the serialized contents of the database.(2)作用 1)数据导入 一般来说,我们是通过数据库工具(如:Navicat,DBeaver)…

印象助手发布更新v1.2.4

本次发布印象助手v1.2.4的更新主要有对从enex转换出来的markdown(MD)文件进行编码修正. 例如MarginNote的笔记转到印象笔记(或者国际版Evernote)里, 再从印象笔记(Evernote)的enex转成markdown就会出现少许字符变成乱码, 这是MarginNote造成的. 本软件会尽最大努力进行修复, 但…

Ubuntu22.04 LTS 部署harbor-v2.7.2高可用

Ubuntu22.04 LTS 部署harbor高可用 一、harbor 环境部署 1. 下载harbor包 [root@harbor01:~]# wget https://github.com/goharbor/harbor/releases/download/v2.7.2/harbor-offline-installer-v2.7.2.tgz2. 解压软件包 [root@harbor01:~]# tar xf harbor-offline-installer-v2.…

PolarCTF-Pwn(困难)WP

1、ret2libc 前期准备:int __fastcall main(int argc, const char **argv, const char **envp) {char s[112]; // [rsp+0h] [rbp-70h] BYREFsetvbuf(stdin, 0LL, 2, 0LL);setvbuf(stdout, 0LL, 2, 0LL);setvbuf(stderr, 0LL, 2, 0LL);gets(s);puts(s);return 0; }因为程序是动…

游戏产业加速鸿蒙化步伐:超1800款鸿蒙原生游戏已上架

2024年度中国游戏产业年会于12月12日至13日北京市首钢国际会展中心举办,华为终端云全球生态发展与销售部副总裁张思建受邀出席主论坛,并发表了主题演讲。同期,由华为游戏中心主办的鸿蒙游戏行业论坛也在北京石景山区举行,本次活动邀请了中国音像与数字出版协会常务副理事长…