Mysql进阶【1】论述索引,索引数据结构,MVCC

news2024/10/6 14:33:04

1. ReadView 案例,解释为什么 RR 和 RC 隔离级别下看到查询结果不一致

案例 01- 读已提交 RC 隔离级别下的可见性分析

开启两个回话,会话事务级别都是READ-COMMITED;

 

操作步骤

  1. 开启两个数据库会话,设置事务为提交读
  2. 事务2查询id=1数据,查询到的是linda
  3. 事务1提交事务
  4. 事务2查询id=1的数据,任然为Recentlyzhuzhu2
  5. 事务1对id=1的数据进行修改,修改为linda
  6. 两边开启事务,两边对查询id=1的数据,为Recentlyzhuzhu2

案例过程

 

结论与分析

  • 提交读,解决了幻读跟不可重复读
  • 但是存在幻读的问题,在事务2中同一条查询查到不同的数据

案例 02- 可重复读 RR 隔离级别下的可见性分析

开启两个回话,会话事务级别都是REPEATABLE-READ

 

操作步骤

  1. 开启两个数据库会话,设置事务为可重复读
  2. 事务1查询id=1数据,查询到的是zhuting2
  3. 事务2提交事务
  4. 事务1查询id=1数据,查询到的是Recentlyzhuzhu
  5. 事务2对id=1数据进行更新为zhuting2
  6. 事务2查询id=1的数据,任然为linda
  7. 事务1对id=1的数据进行修改,修改为zhuting,事务1再次修改Recentlyzhuzhu
  8. 两边开启事务

案例过程

 

结论与分析

  1. 可重复读,在本会话中查询到的数据都是一致的,解决了幻读,不可重复读,脏读,即使事务1提交了事务,在事务2的会话中还是读取到最原始的数据。
  2. 当事务1对数据进行update,事务2在进行update就会进行等待,修改的时候会自动加上锁,当事务1提交事务,锁自动解开,事务2完成数据的修改。

什么是索引?

要点:

1.优点是什么?

  • 加快查询速度
  • 降低数据库io的成本,快速的检索,减少磁盘io,提高整体性能减少磁盘磨损
  • 索引对数据进行了排序,降低了数据的排序成本,降低CPU的消耗
  • 索引可用于实施约束,例如唯一或主键约束,这有助于确保数据完整性并防止数据重复。

2.缺点是什么? 

  • 索引会占据磁盘空间
    • 索引的数据结构是B+ Tree结构,索引的存在需要存储额外的数据,指针,键值对等根据索引类型的不同看存储的是键还是键值对。
    • 数据表可以存在多个索引,每个索引都需要占据磁盘空间,若多个索引,那么就需要占据更多的磁盘空间
    • 在对数据进行插入,删除,修改的时候,索引也需要随着数据的变化而做出修改,若索引的结构增大,占用磁盘的空间也会变大
  • 索引的存在也会降低更新表的效率,加上索引的话Mysql需要保存数据,也需要维护索引文件,所以降低了效率

3.索引分类有哪些?特点是什么?

索引类型

  • 单列索引
    • 主键索引:primary key
    • 前缀索引
    • 空间索引:支持OpenGIS几何数据模型
    • 全文索引:只有文本类型字段能创建fulltext,通过march(列)..against(字符串)的形式进行检索
    • 唯一索引:unique
    • 普通索引
  • 组合索引
    • 需要遵循最左匹配原则
  • MYISAN索引
    • 主键索引
    • 索引文件存储.MYI文件中,数据文件存储在.MYD文件中
    • 索引文件存储的是磁盘地址,最终数据需要根据地址到数据文件中查找
    • 会将索引阶段存储在MySql缓存中,数据缓存依赖于操作系统自身缓存
  • 辅助索引
    • 叶子节点存储磁盘地址,但是辅助索引的键值可以重复不唯一
    • 等值查询也需要按照范围查询的方式进行索引数检索数据。
  • Innodb索引
    • 聚簇索引,一般为主键索引,没有主键的时候会使用表里的唯一索引充当,没有唯一索引则创建隐藏列rowid构成聚簇索引
    • 索引跟数据都存在.idb中
    • 主键索引
      • innodb中要求必须有一个主键索引
      • 并且主键索引叶子简单会存储数据行
  • 辅助索引
    • 非主键索引列,叶子节点只会存储主键值
  • 组合索引
    • 满足最左匹配原则,优化器会根据组合索引优化where后边的条件
  • 覆盖索引
    • 当所查询的列能够在辅助索引数中全部查到,并且可以直接范围,不用会表查询

 

4.索引创建的原则是什么?

  1. 表记录很少不需要创建索引
  2. 频繁出现where条件,排序,分组字段的需要创建索引提高性能
  3. 频繁查询的列,可以创建索引
  4. 多表关联,两边都有的字段可以创建索引
  5. 一个表不能有过多的索引
  6. 无序的列最好别做索引
  7. 最好使用组合索引,多个单索引浪费空间,组合索引可以把频繁的列放在最前面
  8. 避免使用很长的字段做索引

5.有哪些使用索引的注意事项?

  1. like,or,is not null,is null ,!=,<>,字段的使用会使得索引失效
  2. select * 全查索引也会失效
  3. 使用函数,计算,类型转换索引会失效
  4. 字符串不加单引号索引会失效

6.如何知道 SQL 是否用到了索引?

  1. 通过explain语句查看

7.索引的原理是什么?「重点」

索引的底层使用了B+ Tree,数据结构,可以满足等值查询,范围查询等数据库查询的一切要求,并且B+ Tree的时间复杂度控制在O(logn)

  • hash表不适合做聚合和范围查询,虽然速度很快,但是范围查询的haul需要全表扫描所有符合条件的数据
  • 二叉查找树,时间复杂度根据树的高度而改变,会出现瘸腿二叉树的情况,一旦出现这种情况就会全表扫描符合条件的数据,对磁盘io不友好
  • 红黑树,去除了二叉树会出现的树结构不平衡的情况,并且能够很好的划分数据的结构,但是不支持范围查询,时间复杂度O(log2n),并且树有多高就需要检索多少次,磁盘读取数据的时间就会增多
  • B树,改进的二叉树降低了树的高度,数据根据没有磁盘存储,每个节点都存储着多个元素,所有叶子节点处于同一层,但是没有指针相连接,虽然B数让磁盘io的次数减少了,但是不支持范围查询的快速查找,查找到范围查询的第一个值之后需要重新返回根节点进行多次查询,并且数据存储的是行记录,随着列数增多而空间增大。
  • B+树,非叶子节点不存储数据,并且叶子节点之间通过指针相连接,改进了B数的缺点,降低了树的高度,减少磁盘IO,并且叶子节点双向指针,并且有序,提高了查找的效率

什么是 MVCC?

要点:

1.Undo 日志

  • Redo记录了事务的行为,通过Redo可以对数据进行重做。而Undo日志记录数据,回滚使用的还是Undo日志。
  • 未提交读跟串行化加锁不存在Undo日志,可重复读,跟提交读需要用到版本链跟undo日志
  • 对于更新和修改操作,InnoDB并不是删除Undo里边的记录而是将数据删除标志修改为1.并且需要回收机制进行回收。Undo日志有两种,一种插入日志,一种更新日志,插入数据本身只能在本事务中能看到,所以插入日志在事务提交的时候就会被删除。更新日志事务提交不删除,存入指定位置,需要线程进行删除。
  • Undo存放在段中也就是存放在系统表空间的段中
  • 在对数据新增和修改的时候存在,会产生Redo日志,也会存在Undo日志。也就是事务或者语句执行失败了,可以使用Undo日志恢复数据到修改之前,MVCC中的Undo日志使得事务可以做到读不加锁,读写不冲突。

2.ReadView

  • 多并发控制版本链。ReadView可以判断那个版本的Undo日志是否在本事务中可读
  • 版本链中存在4个列
  • 版本链在第一次查询的时候会生成
  • ReadView是一种存储事务id的表,主要包含当前系统中活跃的读写事务的版本id
    • m_ids:活跃列表事务id集合
    • m_low_limit_id:版本链事务id下限,当前活跃事务id的最小值,m_ids中的最小事务id
    • m_up_limit_id:版本链事务id上限,系统中应该分配给下一个事务的id的值
    • m_creator_trx_id:生产当前版本链的事务id

3.如何判断可见性

  • 每个事务都具有版本链,通过版本链ReadView和Undo日志
  • 提交读每次查询都会生成一个事务id,可重复读一次事务中的查询都是一个事务di
  • 事务开启第一次查询的时候会生成版本链,根据Undo日志跟ReadView
    • 如果被访问的版本trx_id事务id小于ReadView版本链id最小值,表明改事务已经提交,可以被看见
    • 事务id等于事务链上的编号,可以被看见
    • 事务id大于版本链id,不能被看见
    • 事务id在版本链最大值与最小值之间,事务id与版本链这部分的列表内id相对应则不能看见,不与之对应能看见

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

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

相关文章

zerotier使用

目标 使用zerotier进行内网穿透&#xff0c;使外网客户端访问内网服务器 步骤 1.1 注册 进入zerotier官网&#xff0c;注册 ​ 完成后进入个人中心&#xff0c;点击networks&#xff0c;选择创建网络&#xff0c;得到一个networkid ​ 点击id进入设置&#xff0c;编辑名称…

程序员——毕业年薪28w真的不可能吗?

我是一名来自湖南的普通应届毕业生。目前就职于杭州的一家电商经营的公司&#xff0c;做数据开发工程师&#xff0c;工资是20k*14薪&#xff0c;并且是每周三发一次工资。 在大学期间&#xff0c;我选择了学习计算机相关专业&#xff0c;但是课堂上所学的知识常常让我觉得晦涩…

仙境传说RO :ra脚本加载结构和开发语法讲解

仙境传说RO &#xff1a;ra脚本加载结构和开发语法讲解 大家好&#xff0c;我是艾西。上一篇文章中我们聊完了怎么在游戏中新建NPC&#xff0c;感觉还是有不少小伙伴没有太看懂原理。今天艾西给大家深度讲解一下脚本加载结构和开发语法环境文档。 我们最后都是以ra脚本为主要…

提高客户满意度的4种方式

随着技术的使用越来越多&#xff0c;客户体验格局已经永远改变了。长时间的等待时间和缓慢的响应不再被接受&#xff0c;并且对客户满意度产生巨大影响。即时满足和满足客户的高期望至关重要。 那么如何提高客户满意度呢&#xff0c;接下来将为您推荐五种最常见的方法&#xf…

SpringCloud Alibaba Sentinel学习

SpringCloud Alibaba Sentinel 1. Sentinel 使用 第一步、下载Sentinel的jar包&#xff0c;并且在命令行输入 java -jar sentinel-dashboard-1.8.0.jar 启动jar包 第二步、在项目中添加Sentinel依赖 <!--引入 alibaba-sentinel 场景启动器--> <dependency><g…

【每日算法】【171. Excel 表列序号】

☀️博客主页&#xff1a;CSDN博客主页 &#x1f4a8;本文由 我是小狼君 原创&#xff0c;首发于 CSDN&#x1f4a2; &#x1f525;学习专栏推荐&#xff1a;面试汇总 ❗️游戏框架专栏推荐&#xff1a;游戏实用框架专栏 ⛅️点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd;&…

Cookie和session工作流程详解

目录 cookie机制 session会话 理解会话机制 Servlet中对Cookie和Session提供的 HttpServletrequest类中的方法&#xff1a; 模拟实现登录功能 首先实现功能分为两个界面&#xff1a; &#xff08;1&#xff09;登录页面代码&#xff08;前端代码&#xff09; (2) 编写Lo…

docker cgroup资源占用及docker的镜像创建

cgroup用来资源限制 包括cpu&#xff0c;内存&#xff0c;磁盘三大方面 基本复写了常见的资源配额和使用量控制 cgroup是controlgroup的缩写 设置cpu使用率的上限 linux通过cfs&#xff08;完全公平调度器&#xff09;来调度各个进程对cpu的使用&#xff0c;cfs默认的调度…

Maven 介绍,根据 Maven 官方文档整理

这部分内容主要根据 Maven 官方文档整理&#xff0c;做了对应的删减&#xff0c;主要保留比较重要的部分&#xff0c;不涉及实战&#xff0c;主要是一些重要概念的介绍。 Maven 介绍 Maven 官方文档是这样介绍的 Maven 的&#xff1a; Apache Maven is a software project man…

OpenGL 着色器简介

1.简介 着色器(Shader)是运行在GPU上的小程序。这些小程序为图形渲染管线的某个特定部分而运行。从基本意义上来说&#xff0c;着色器只是一种把输入转化为输出的程序。着色器也是一种非常独立的程序&#xff0c;因为它们之间不能相互通信&#xff1b;它们之间唯一的沟通只有通…

Python数据攻略-DataFrame的数据计算和整理

大家好&#xff0c;我是Mr数据杨。今天&#xff0c;我们要踏上一场探索Python的旅程&#xff0c;途中我们将讲解算术运算、NumPy和SciPy函数的应用、DataFrame的排序、过滤、统计和遍历等技巧。想象一下如果《三国演义》中的诸葛亮有了Python的帮助&#xff0c;他将如何更有效地…

java debug调试工具

文章目录 java debug调试工具debugdebug运行断点如何运行 具体使用step intostep into Force step intoresume programstopview breakpointsmute breakpointsstep ourt Shift消除debug java debug调试工具 debug 就是调试工具&#xff0c;用来查看代码在运行工程数据的变化。 …

尚硅谷大数据hadoop教程_yarn

p125 课程介绍 p126 yarn基础架构 YARN主要由ResourceManager、NodeManager、ApplicationMaster和Container等组件构成。 p127 工作机制 &#xff08;1&#xff09;MR程序提交到客户端所在的节点。 &#xff08;2&#xff09;YarnRunner向ResourceManager申请一个Applicatio…

一本书让你彻底搞懂安卓系统性能优化(文末送书5本)

&#x1f935;‍♂️ 个人主页&#xff1a;艾派森的个人主页 ✍&#x1f3fb;作者简介&#xff1a;Python学习者 &#x1f40b; 希望大家多多支持&#xff0c;我们一起进步&#xff01;&#x1f604; 如果文章对你有帮助的话&#xff0c; 欢迎评论 &#x1f4ac;点赞&#x1f4…

c盘清理软件:清理垃圾、扩大c盘和系统迁移

一、为什么要c盘清理软件 Windows系统采用了NTFS文件系统&#xff0c;这种文件系统特点是有文件碎片和系统产生的临时文件会大量存储到系统盘上&#xff0c;而且在使用电脑的过程中&#xff0c;由于程序的安装、升级、卸载和其他操作会产生大量无用的垃圾文件&#xff0c;这些…

文心一言 VS 讯飞星火 VS chatgpt (32)-- 算法导论5.2 4题

四、利用指示器随机变量来解如下的帽子核对问题(hat-heck problem):n位顾客&#xff0c;他们每个人给餐厅核对帽子的服务生一顶帽子。服务生以随机顺序将帽子归还给顾客。请问拿到自己帽子的客户的期望数是多少? 文心一言&#xff1a; 我们可以将这个问题转化为求解在指示器…

Java的Comparator升序降序的记法

在使用Java自带的排序函数时&#xff0c;往往需要根据自己的需求自定义比较器。以前一直对Comparator的升序降序疑惑。现在记录一下&#xff0c;加深下印象。 先给结论&#xff1a; 实现Comparator接口&#xff0c;必须实现下面这个函数&#xff1a; Override public int co…

Vue+springboot电动车共享电池租赁管理系统设计与实现

基于java语言、Springboot框架、B/S架构、Mysql数据库设计并实现了共享电动车电池管理系统设计与实现。系统主要包括首页、个人中心、用户管理、维护人员管理、商户管理、区域信息管理、电池信息管理、租赁订单管理、归还订单管理、费用订单和定、提醒信息管理、维护信息管理、…

基于vue3+mqtt实现的远程串口实时调试助手(网络透传)

软件&#xff1a;串口调试助手&#xff08;基于MQTT消息协议实现多客户端同时订阅模式&#xff09; 扩展&#xff1a;手机端H5(websocket&#xff09;和vue3mqtt实现的接收客户端 用途&#xff1a;本地化串口调试&#xff0c;远程技术支持时可用&#xff0c;实时同步透传&…

Docker容器操作

#容器创建&#xff1a;就是将镜像加载到容器的过程。 新创建的容器默认处于停止状态&#xff0c;不运行任何程序&#xff0c;需要在其中发起一个进程来启动容器。 格式&#xff1a;docker create [选项] 镜像 常用选项&#xff1a; -i&#xff1a;让容器开启标准输入接受用户输…