关于Mysql基本概念的理解

系列文章
关于时间复杂度o(1), o(n), o(logn), o(nlogn)的理解

关于HashMap的哈希碰撞、拉链法和key的哈希函数设计

关于JVM内存模型和堆内存模型的理解

关于代理模式的理解

关于Mysql基本概念的理解

关于软件设计模式的理解

文章目录

  • 前言
  • 一、事务隔离级别
  • 二、存储引擎
    • 1.事务支持
    • 2.行级锁和表级锁
  • 三、B+树的索引结构以及索引覆盖、回表查询
    • 1.B+树的索引结构
    • 2.理解索引覆盖查询和回表查询
      • 覆盖索引查询
      • 回表查询
  • 四、日志文件
  • 五、MVCC


前言

MySQL是众多Java开发者首选的数据库之一,因为其是一个开源的关系型数据库管理系统,拥有庞大的用户社区和活跃的开发者生态系统。在处理大规模数据和高并发请求时表现优异。与Java的兼容性非常好,提供了多种Java开发所需的接口和驱动程序。它提供了事务支持、ACID特性以及数据复制和故障恢复机制,确保数据的一致性、持久性和可靠性。同时,MySQL支持水平和垂直两种方向的扩展,可以根据应用程序的需求进行灵活的扩展和配置。

一、事务隔离级别

MySQL默认的事务隔离级别是 “可重复读”(Repeatable Read)。这意味着在同一个事务中,多次读取相同的数据会得到相同的结果,即使其他事务对数据进行了修改或插入操作,也不会影响当前事务中的读取结果。MySQL的可重复读隔离级别通过使用快照读(Snapshot Read) 和在事务中保持一致的读取视图来实现。。

二、存储引擎

最常见的包括InnoDB和MyISAM,它们在设计和功能上有一些显著的区别:

1.事务支持

InnoDB引擎支持事务,具有ACID(原子性、一致性、隔离性、持久性)特性,可以确保数据的完整性和一致性。而MyISAM引擎不支持事务,因此在需要事务支持的应用场景下不太适用。

2.行级锁和表级锁

InnoDB引擎支持行级锁,可以在并发访问时提高性能并减少锁冲突。而MyISAM引擎只支持表级锁,因此在高并发环境下可能会出现较多的锁竞争,影响性能。

三、B+树的索引结构以及索引覆盖、回表查询

1.B+树的索引结构

B+ 树是一种多路平衡查找树,它的特点是非叶子节点存储索引值,叶子节点存储实际数据。
在 B+ 树中,叶子节点之间通过指针进行连接,形成一个有序的链表,便于范围查询。
B+ 树的非叶子节点通常称为索引节点,叶子节点存储数据,最底层的叶子节点称为数据页,存储实际的数据记录。

2.理解索引覆盖查询和回表查询

覆盖索引查询

覆盖索引查询是指查询操作所涉及的字段都包含在了索引中,查询结果可以直接从索引中获取的查询操作。
在 B+ 树结构中,覆盖索引查询可以直接在索引的叶子节点上完成。因为叶子节点存储了索引字段的值以及数据行的指针或主键值,如果查询所需的字段都在索引中,那么可以直接从叶子节点获取这些值,并返回给用户,无需额外的数据检索操作。

回表查询

回表查询是指在使用索引进行查询时,需要根据索引中的指针或主键值,再次到数据页(叶子节点)中检索实际的数据记录,才能获取查询结果的查询操作。
在 B+ 树结构中,回表查询涉及到从索引的叶子节点(包括底层叶子节点)回溯到对应的数据页,然后再获取实际的数据记录。
回表查询会在叶子节点和底层叶子节点之间发生,因为索引叶子节点中只存储了索引字段的值和指向数据行的指针或主键值,而实际的数据记录存储在底层叶子节点中。因此,回表查询的结果返回层级通常是底层叶子节点。

综上所述,覆盖索引查询的结果返回层级通常是索引的叶子节点,而回表查询的结果返回层级通常是底层叶子节点,因为回表查询需要到底层叶子节点中获取实际的数据记录。

四、日志文件

在 MySQL 中,底层的日志文件主要包括以下几种:

错误日志 (Error Log): 错误日志是 MySQL 服务器记录所有错误、警告以及其他相关信息的文件。它包含了服务器启动和运行过程中的诊断信息,以及一些重要事件的记录。错误日志对于故障排除和性能优化非常重要。

查询日志 (Query Log): 查询日志记录了所有到 MySQL 服务器的查询请求,包括对数据库的读取和写入操作。启用查询日志可以帮助跟踪应用程序对数据库的访问情况,便于性能优化和安全审计。

慢查询日志 (Slow Query Log): 慢查询日志记录了执行时间超过阈值的查询语句。通过分析慢查询日志,可以发现性能瓶颈,并对查询进行优化,提高数据库的响应速度。

二进制日志 (Binary Log): 二进制日志包含了对数据库执行的所有更改操作,以二进制格式记录。它用于数据复制(replication)、故障恢复以及点播(point-in-time recovery)等场景。通过二进制日志,可以在主服务器上记录所有更改并将其传输到一个或多个从服务器,从而实现数据复制。

重做日志 (Redo Log): 重做日志记录了已经提交的事务对数据库所做的修改。它确保了事务的持久性,即使在系统崩溃或断电时,MySQL 也能够通过重做日志来恢复数据。

回滚日志 (Undo Log): 回滚日志记录了事务执行过程中的撤销操作,用于事务的回滚和 MVCC 的实现。它记录了事务对数据的修改操作及其对应的版本信息,在事务回滚或系统崩溃时,可以利用回滚日志来恢复数据到事务开始之前的状态。

这些日志文件在 MySQL 中起着不同的作用,对于数据库的管理、维护和故障恢复都至关重要。

五、MVCC

MVCC(Multi-Version Concurrency Control)是MySQL等数据库系统中用于实现并发控制的一种技术。它允许多个事务在同时对数据库进行读写操作时,能够达到较高的并发性而不产生数据不一致的问题。

MVCC的核心思想是在数据被修改时不直接覆盖原始数据,而是创建新版本的数据,并且在事务开始时确定一个可见性规则,以确保事务只能看到适当版本的数据。这样,在事务中对数据进行读取时,可以根据事务开始时创建的一致性读取视图来获取数据,而不会受到其他事务修改的影响。

下面是MVCC的几个关键概念:

版本号: 每个数据行都会关联一个版本号或者时间戳,用来标识该数据行的版本信息。当数据被修改时,会创建一个新的版本,并更新版本号。

数据行的状态: 在MVCC中,数据行可以处于不同的状态,比如已提交、未提交等。这些状态可以用来判断事务是否能够看到该行的数据。

Read View(读取视图): 在事务开始时,MySQL会为当前事务创建一个一致的读取视图。这个读取视图包含了事务开始时数据库中所有数据行的版本信息。在事务执行期间,该读取视图保持不变,以确保事务读取到的数据是一致的。

可见性规则: 在MVCC中,对数据行的读取要符合可见性规则。一般情况下,事务只能看到已提交状态的数据,而看不到未提交或已经被删除的数据。

MVCC的实现使得数据库系统在并发访问时能够保持数据的一致性,并且提高了系统的并发性能。MySQL通过MVCC来实现不同的隔离级别,包括可重复读隔离级别。通过维护一致的读取视图和版本控制,MySQL可以实现事务的隔离性,并且避免了读取操作受到其他并发事务修改的影响。

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

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

相关文章

【Python爬虫】案例_斗鱼

声明:案例只用于学习,不得恶意使用 要求:获取直播间标题、类型、主播、热度,并实现翻页 定位随着网站更新可能不会实现,请自行更改 from selenium import webdriver from selenium.webdriver.chrome.options import…

【uniapp】CSS实现多行文本展开收起的文字环绕效果

1. 效果图 收起状态 展开状态 2. 代码实现 <view class"word-wrap" id"descriptionTxt"><view class"fold-text" v-if"isFold"><text class"fold-btn" click"changFold">全文</text&g…

【网络安全】Linux 应急响应-溯源-系统日志排查知识点

Linux 应急响应-溯源-系统日志排查知识点汇总 1. 查看当前已经登录到系统的用户 (w 命令) w2. 查看所有用户最近一次登录 (lastlog 命令) lastlog lastlog | grep -v "Never logged in"3. 查看历史登录用户以及登录失败的用户 (last 和 lastb 命令) last lastb4. …

使用docker完整搭建前后端分离项目

1、docker的优势&#xff0c;为啥用docker 2、docker的核心概念 镜像【Image】- 只读模板 容器【Container】- 运行镜像的一个外壳&#xff0c;相当于一个独立的虚拟机 仓库【repository】- 镜像的管理工具&#xff0c;可公开&#xff0c;可私有&#xff1b;类似git仓库 3、c…

【前端】js通过元素属性获取元素

【前端】js通过元素属性获取元素 <div for"hc_opportunity_config">aaaaa</div>//通过属性获取元素document.querySelector([for"hc_opportunity_config"]) document.querySelector([属性"属性值"])

操作教程|通过DataEase开源BI工具对接金山多维表格

前言 金山多维表格是企业数据处理分析经常会用到的一款数据表格工具&#xff0c;它能够将企业数据以统一的列格式整齐地汇总至其中。DataEase开源数据可视化分析工具可以与金山多维表格对接&#xff0c;方便企业更加快捷地以金山多维表格为数据源&#xff0c;制作出可以实时更…

包拯断案 | MySQL5.7替换路上踩过的坑 一键get解决办法@还故障一个真相

提问&#xff1a;作为DBA运维的你&#xff0c;是否有过这些烦恼 1、业务系统进行替换投产时&#xff0c;发现数据库回放并行度低 2、虽然2个数据库集群使用同一份数据&#xff0c;却在关闭双一后&#xff0c;二级从库的回放效率依旧缓慢&#xff0c;不知是什么原因&#xff1f…

机器人开源项目分享,助力一户一机器人

最初&#xff0c;因隋炀帝思念心切&#xff0c;命工匠按照柳抃的形象制作了木偶机器人&#xff0c;被认为是历史上最早的机器人之一。这些木偶机器人通过精巧设计的机关&#xff0c;能够执行坐、起、拜、伏等动作。 如今&#xff0c;随着科技的发展&#xff0c;机器人已经广泛…

从ES5迈向ES6:探索 JavaScript 新增声明命令与解构赋值的魅力

个人主页&#xff1a;学习前端的小z 个人专栏&#xff1a;JavaScript 精粹 本专栏旨在分享记录每日学习的前端知识和学习笔记的归纳总结&#xff0c;欢迎大家在评论区交流讨论&#xff01; ES5、ES6介绍 文章目录 &#x1f4af;声明命令 let、const&#x1f35f;1 let声明符&a…

Linux磁盘初始化与fstab文件更新

环境&#xff1a; Redhat 7.9 本文操作&#xff1a; >>给disk设置分区 &#xff08;fdisk&#xff09; >>给disk设置file system格式 (mkfs ) >>创建路径&#xff0c;并将disk mount上(mkdir和mount ) >>修改fstab文件 初始化Disk 初始化前&#xff…

Vue组件通信 - 组件传值 / 什么是组件

1.什么是组件通信&#xff1a; 组件&#xff08;.vue&#xff09;通过某种方式来传递信息以达到某个目的 2.组件通信可以解决什么问题&#xff1a; 每个组件之间都有独立的作用域&#xff0c;组件间的数据是无法共享的&#xff0c;但在实际开发中我们常常需要让组件之间共享…

【计算机网络原理】对传输层TCP协议的重点知识的总结

˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如…

Spring Bean Map漫游:遍历背后的生命周期奥秘

1. 引言 在Spring框架中&#xff0c;Bean的生命周期是一个复杂而精妙的过程。其中&#xff0c;遍历存储Bean实例的Map&#xff08;通常是DefaultSingletonBeanRegistry中的singletonObjects&#xff09;是这一过程中的重要环节。理解这个遍历过程以及它在Bean生命周期中的作用…

桌面文件不见了怎么恢复?五种方法解决文件恢复难题,建议收藏

不小心误删除了桌面文件&#xff0c;导致文件丢失。事实上误删的文件并没有被永久删除&#xff0c;而是被移动到了回收站中&#xff0c;可以恢复这些文件。本文将分享多种方法&#xff0c;具体步骤如下。 方法一&#xff1a;从回收站中恢复 大多数操作系统都有回收站或垃圾桶的…

【C语言】结构体内存对齐:热门面试话题

&#x1f525;引言 书接上文&#xff0c;我们了解关于结构体的基本知识&#xff0c;这篇将深入剖析结构体中一个重要的知识点:内存对齐 关于内存对齐是属于热门面试话题&#xff0c;对此单独放在一篇来分享 &#x1f308;个人主页&#xff1a;是店小二呀 &#x1f308;C语言笔记…

3D工业视觉

前言 本文主要介绍3D视觉技术、工业领域的应用、市场格局等&#xff0c;主要技术包括激光三角测量、结构光、ToF、立体视觉。 一、核心内容 3D视觉技术满足工业领域更高精度、更高速度、更柔性化的需求&#xff0c;扩大工业自动化的场景。 2D视觉技术基于物体平面轮廓&#…

软件无线电学习-第二代移动通信系统过程理解

本文知识内容摘自《软件无线电原理和应用》 无线通信领域让大家感受最深的是民用移动通信的快速发展。民用移动通信在短短的二十年时间里已发展了三代&#xff1a;20世纪80年代的模拟体制(TACS/AMPS)为第一代移动通信(简称1G)&#xff1b;20世纪90年代的数字体制(GSMCDMATDMA)…

Git提交和配置命令

一、提交代码到仓库 在软件开发中&#xff0c;版本控制是一个至关重要的环节。而Git作为目前最流行的版本控制系统之一&#xff0c;为我们提供了便捷高效的代码管理和协作工具。在日常开发中&#xff0c;我们经常需要将本地代码提交到远程仓库&#xff0c;以便于团队协作和版本…

2024电工杯数学建模B题思路模型代码

完整内容更新见文末名片 B 题&#xff1a;大学生平衡膳食食谱的优化设计及评价 大学时代是学知识长身体的重要阶段&#xff0c;同时也是良好饮食习惯形成的重要时期。这一特 定年龄段的年轻人&#xff0c;不仅身体发育需要有充足的能量和各种营养素&#xff0c;而且繁重的脑…

Java基础教程 - 9 集合

更好的阅读体验&#xff1a;点这里 &#xff08; www.doubibiji.com &#xff09; 更好的阅读体验&#xff1a;点这里 &#xff08; www.doubibiji.com &#xff09; 更好的阅读体验&#xff1a;点这里 &#xff08; www.doubibiji.com &#xff09; 9 集合 什么是集合&…