MySQL 默认的事务隔离级别是什么?为什么选择这个级别?

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

MySQL 默认的事务隔离级别是什么?为什么选择这个级别?

在 MySQL 中,默认的事务隔离级别是 可重复读(Repeatable Read)。这是 InnoDB 存储引擎的默认事务隔离级别。


为什么选择 "可重复读" 作为默认隔离级别?

1. 解决不可重复读问题

  • 不可重复读 是指在同一事务内,连续两次读取同一数据时,数据的值可能发生变化,因为其他事务修改了该数据并提交。
  • 可重复读 隔离级别保证了在一个事务内,无论多少次读取数据,结果都是一致的,避免了 不可重复读 问题。这样,应用程序在执行多次读取操作时,确保每次读取的数据都是一致的,从而减少了数据不一致的风险。

2. 较高的并发性能

  • 相比于 串行化 隔离级别,可重复读 提供了较好的并发性能。虽然 可重复读 允许事务间的并发执行,但它通过保证数据读取的一致性,避免了多个事务对同一数据的修改冲突,同时避免了大范围的锁竞争和资源浪费。
  • 它是一个 折中方案,在 性能一致性 之间做了平衡。

3. 减少幻读问题的影响

  • 幻读 是指在同一事务中,第一次查询时没有返回某些数据,第二次查询时却因为其他事务插入了数据,导致查询结果发生变化。
  • 可重复读 隔离级别无法完全解决幻读问题,但在 InnoDB 存储引擎中,通过使用 下一键锁(Next-Key Lock),可以有效减少幻读的发生,从而为大多数应用场景提供足够的数据一致性和隔离性。

4. 适用于大多数应用场景

  • 可重复读 在大多数应用中提供了足够的隔离性,尤其是那些需要 读操作的一致性 但对性能要求也较高的系统。
  • 它能够有效处理事务中的读取操作,减少由于并发导致的数据错误,同时不需要像 串行化 那样牺牲过多的性能。

总结

  • MySQL 默认的事务隔离级别是 可重复读(Repeatable Read)
  • 选择这个级别是因为它在 一致性并发性 之间提供了合理的折衷,能够解决 不可重复读幻读 等常见问题,并且在大多数应用场景下提供了较高的性能。
  • 可重复读 隔离级别是 InnoDB 引擎的默认选择,它通过 下一键锁 减少了幻读问题的影响,因此在多数情况下都能满足大部分数据库应用的需求。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/852738.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日北京市首钢国际会展中心举办,华为终端云全球生态发展与销售部副总裁张思建受邀出席主论坛,并发表了主题演讲。同期,由华为游戏中心主办的鸿蒙游戏行业论坛也在北京石景山区举行,本次活动邀请了中国音像与数字出版协会常务副理事长…