【剧前爆米花--爪哇岛寻宝】MySQL中索引和事务

news2024/11/18 3:18:33

作者:困了电视剧

专栏:《MySQL数据库》

文章分布:这是一篇关于Java中异常类的文章,在本篇文章中详细讲解了异常的使用逻辑和底层的执行过程,如有疏漏,欢迎大佬指正!

目录

索引

用法

底层逻辑

事务

并发执行事务可能产生的问题

脏读问题

不可重复读

幻读 


索引

索引是一种特殊的文件,包含着对数据表里所有记录的引用指针。可以对表中的一列或多列创建索
引, 并指定索引的类型,各类索引有各自的数据结构实现。
1.数据库中的表、数据、索引之间的关系,类似于书架上的图书、书籍内容和书籍目录的关     系。
2.索引所起的作用类似书籍目录,可用于快速定位、检索数据。
3.索引对于提高数据库的性能有很大的帮助。 

用法

create index 索引名 on 表名 ( 字段名 );
当我们将数据放入一个表中时(这里先假定这个表的名字是student,表中存储的是student的
个人信息),如果只是一个客户端并且此时数据库中的数据很少,那MySQL的服务器还可以在极短的时间里完成处理,但如果数据库中存储的数据很多呢?那当我们想进行查询的时候就需要一条一条数据的进行比较,如果此时又不止一个客户端访问数据库而是很多的客户端同时访问数据库呢?那需要的时间又需要增加许多。
这就造成了很多麻烦,为了解决这一问题,MySQL采用的方法之一就是建立一个索引。当你建立了一个索引时在进行查找就会大大降低所消耗的时间,但是这同时也存在一个弊端,当你需要对数据库中的数据进行更改的时候,那你的目录(索引)就也要进行相应的更新,这就增加了操作所需要的时间。
现在可能有人要问了,这索引这么玄乎,那他底层的原理是什么?

底层逻辑

当创建一个MySQL的索引,就是构建一个B+树,这个树中的元素就是数据库中存储的内容。

我们在了解B+树之前先了解什么是B树,B树又称B-树,是一个n叉搜素树,如图所示

此时我们发现如果数据库中的数据按这种方式进行排列的话,数据参差不齐很难找到我们需要的数据,此时就需要我们的B+树来进行安排了。

除了叶子节点,其他节点保留的仅仅是一个键值也就是用primary定义的key,然后最后一排的叶子节点中存储的才是每一个完整的数据,就比如如果是学生,那叶子节点以外的存储的是id编号,而叶子结点存储的则是每一个学生的姓名,班级等等。

B+数会使所有的数据都出现在叶子节点上,并且叶子节点都在同一个高度,这就使查找的时候效率大大增高。 

事务

在生活中我们会遇到这样的问题,当我们再给别人转账的时候,如果我们转出500,在对方账户上进行转入500时发生了错误,那怎么办?我们的500块钱就会这样打水漂了嘛?

不会,为了解决这一问题,MySQL引入了事务这一概念。

事务的本质是将多个sql语句给打包成一个整体,要么全部执行成功,要么就一个都不执行,而不会出现执行一半这种中间状态。这体现了事务最核心的特性——原子性。

注:这里的一个都不执行是,并不是完全不执行,而是如果在执行一半时突然出错了,就停止执行,并将已经执行的部分给进行还原,所以看起来就好像没有执行过一样,这种方式叫做“回滚”。

事务的特性:

1.原子性——最核心的特性。

2.一致性,数据执行前后数据一定要是靠谱的,就比如转500,一个用户少了500,另一个用     户却多了5000,这就是不靠谱的数据。

3.持久性,事务修改的内容是写到硬盘上的,持久存在的,重启也不丢失。

4.隔离性,这个“隔离性”是为了解决“并发”执行事务,引起的问题。

并发执行事务可能产生的问题

脏读问题

在事务A对数据库中的数据进行修改的时候,如果此时事务B进来读了数据,那此时这个事务B读的数据就是脏数据,因为这个数据不是准确的,不确定事务A会不会在进行修改。

为了解决这一个问题,MySQL引入了“写操作加锁”这样的机制,即当事务A在对数据进行修改的时候,事务B不能进行读操作。

不可重复读

当事务A修改好后,此时事务B进行读操作,但当事务B进行读的过程中,事务A又来进行修改了,那事务B读的数据又不准确了。

于是MySQL引入了“读操作加锁”这个机制,是数据的准确性大大增加,提高了事务的隔离性,但同时事务的并发处理能力也下降了。

幻读 

在引入读写加锁后,还可能会出现这样的问题,就是虽然我这一个文件在我读的时候不会发生改变了,但是我可能还有其他很多文件,这些个文件并没有上锁,所以当我一次性读完时,我发现我刚才读的那个没有改变但其他的却发生了变化,这在一些情况下是不允许的。

所以此时,MySQL使用“串行化”这样的方式来解决幻读,彻底放弃并发处理事务。

以上就是本篇博客的全部内容了,如有疏漏欢迎补充指正。

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

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

相关文章

中医药NER命名实体识别基于SPANNER方式

一个不知名大学生,江湖人称菜狗 original author: Jacky Li Email : 3435673055qq.com Time of completion:2023.3.5 Last edited: 2023.3.5 导读 本文使用SPANNER方式实现对中医药进行实体识别,采用focal loss 进行优化。 本文章作用防止安静…

【微信小程序】计算器案例

🏆今日学习目标:第二十一期——计算器案例 ✨个人主页:颜颜yan_的个人主页 ⏰预计时间:30分钟 🎉专栏系列:我的第一个微信小程序 计算器前言实现效果实现步骤wxmlwxssjs数字按钮事件处理函数计算按钮处理事…

为啥一个 main 方法就能启动项目

在 Spring Boot 出现之前,我们要运行一个 Java Web 应用,首先需要有一个 Web 容器(例如 Tomcat 或 Jetty),然后将我们的 Web 应用打包后放到容器的相应目录下,最后再启动容器。 在 IDE 中也需要对 Web 容器…

【WEB前端进阶之路】 HTML 全路线学习知识点梳理(中)

前言 本文是HTML零基础学习系列的第二篇文章,点此阅读 上一篇文章。 文章目录前言六.HTML标题1.HTML标题2.HTML水平线3.HTML 注释七.HTML段落1.HTML段落2.HTML换行八.HTML文本格式化九.HTML链接十.HTML头部十一.HTML图像十二.HTML表格十三.HTML列表十四.HTML区块1.H…

C#:Krypton控件使用方法详解(第十二讲) ——kryptonCheckButton

今天介绍的Krypton控件中的kryptonCheckButton。下面先介绍外观属性:Checked属性:表示控件是否处于已启用状态,属性值为Bool类型,属性值为true时,表示控件处于已选中状态。属性值为false时,表示控件处于不选…

黄河流域公安院校网络空间安全技能挑战赛 QAQ 题解

目录 一.获取pyc文件 二.反编译出.py源码 三.程序逻辑 1.第一个限制条件 2.第二段 3.第三段 这题是对python打包成的可执行程序逆向 如果对如何反编译.pyc和.py文件有疑问可以参考: Python逆向基本操作步骤——以杭电新生赛hgame week2 reverse stream(python3.10逆向)…

IOC(概念和原理)

文章目录1. IOC容器概念2. IOC底层原理3. IOC(接口)4. IOC操作Bean管理(概念)5. IOC操作Bean管理(基于xml方式)5.1 基于xml创建对象5.2 基于xml方式注入属性5.2.1 DI:依赖注入,就是注…

Unable to find a valid cuDNN algorithm to run convolution

Unable to find a valid cuDNN algorithm to run convolution 今天在复习HumanNerf的时候发现了这个报错, import torch print(torch.cuda.is_available()) 使用上面的代码发现GPU是可以用的,可自己的torch版本对应。 后面继续看帖子,总结有…

【C++】30h速成C++从入门到精通(STL介绍、string类)

STL简介什么是STLSTL(standard template libaray-标准模板库):是C标准库的重要组成部分,不仅是一个可复用的组件库,而且是一个包罗数据结构与算法的软件框架。STL的版本原始版本Alexander Stepanov、Meng Lee 在惠普实验室完成的原始版本&…

2D图像处理:九点标定_上(机械手轴线与法兰轴线重合)(附源码)

文章目录 1. 九点标定2. 九点标定流程2.1 机械手轴线与法兰轴线重合代码实现1. 九点标定 在2D视觉抓取项目中,如果想要让机械手准确的抓取到工件,前提是需要知道机械手应该移动到哪里(位姿)。而移动到哪里(位姿)的获取就需要对相机和机械手进行标定。因此,九点标定(2D视…

ESP32设备驱动-MAX6675冷端补偿K热电偶数字转换器

MAX6675冷端补偿K热电偶数字转换器 1、MAX6675介绍 MAX6675执行冷端补偿并将来自K型热电偶的信号数字化。 数据以 12 位分辨率、SPI™ 兼容的只读格式输出。 该转换器可将温度解析为 0.25C,读数高达 +1024C,并且在 0C 至 +700C 的温度范围内具有 8 LSB 的热电偶精度。 MAX…

力扣旋转字符串

🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨ 🐻推荐专栏: 🍔🍟🌯 c语言初阶 🔑个人信条: 🌵知行合一 🍉本篇简介:>:介绍字符串旋转,左旋,右旋即旋转结果. 金句分享: ✨好好干&…

如何通过Java将Word转换为PDF

Word是我们日常编辑文档内容时十分常用的一种文档格式。但相比之下,PDF文档的格式、布局更为固定,不易被更改。在保存或传输较为重要的文档内容时,PDF文档格式也时很多人的不二选择。很多时候我们都会遇到需要将Word转换为PDF的情况。下面我就…

放弃node-sass,启用sass

在下载一个新项目时运行:npm run install 发现报错 npm uninstall 异常 Error: Could not find any Visual Studio installation to use 或是 ------------------------- You need to install the latest version of Visual Studio npm ERR! gyp ERR! find VS incl…

嵌入式Linux(二十四)系统烧写

将uboot,linux kernel,.dtb,rootfs烧写到板子上的EMMC上,避免断网导致不能运行。 1. MfgTool工具介绍 一路解压之后,得到以下两项: ①Profiles文件夹:后续烧写文件放到这个文件夹。  其中关注…

宝塔+docker+jenkins部署vue项目(保姆级教程)

1.使用宝塔安装docker 在软件商城安装Docker管理器 2.使用docker下载jenkins镜像 使用命令行 docker pull jenkins/jenkins:lts //lts表示支持版本较长3.创建并且挂载jenkins目录并赋值 jenkins_home为我创建的目录 可以修改任意目录 mkdir -p /jenkins_home cho…

pytest测试框架——allure报告

文章目录一、allure的介绍二、allure的运行方式三、allure报告的生成方式一、在线报告、会直接打开默认浏览器展示当前报告方式二、静态资源文件报告(带index.html、css、js等文件),需要将报告布置到web服务器上。四、allure中装饰器1、实现给…

【LeetCode每日一题:982. 按位与为零的三元组+从递归超时到记忆化搜索】

题目描述 给你一个整数数组 nums &#xff0c;返回其中 按位与三元组 的数目。 按位与三元组 是由下标 (i, j, k) 组成的三元组&#xff0c;并满足下述全部条件&#xff1a; 0 < i < nums.length 0 < j < nums.length 0 < k < nums.length nums[i] & …

Common API环境部署(保姆级教程,填充了很多坑)

Common API环境部署目录一、前言及结果展示二、Windows下安装docker1. 准备工作[1.1 Docker安装包](https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe)[1.2 Wsl2安装包](https://wslstorestorage.blob.core.windows.net/wslblob/wsl_update_x64.ms…

【数据结构】链式二叉树

前言 在前面我们学习了一些二叉树的基本知识&#xff0c;了解了它的结构以及一些性质&#xff0c;我们还用数组来模拟二叉树建立了堆&#xff0c;并学习了堆排序&#xff0c;可是数组结构的二叉树有很大的局限性&#xff0c;平常我们用的最多树结构的还是链式二叉树&#xff0c…