【MySQL】索引和事务的详细介绍

news2024/11/15 10:36:08

目录

一.索引

1.索引概念

2.查看索引

3.创建索引

4.索引使用的数据结构是什么

1.HASH(不是)

 2.二叉搜索树(不是)

3.B树   N叉数(不是)

 4.B+树(是滴)

 5.组合索引

 6.索引覆盖

7.回表查询

8.索引失效

二.事务

1.概念:

2.事务的使用

1.开启事务:start transaction; 

2.执行多条SQL语句

3.回滚或者提交:rollback/commit;

以rollback为例:

3.事务的特性(ACID)

1.原子性

 2.一致性

3.隔离性

4.持久性

4.事务的隔离级别

1.多个事务之间是否会相互影响

2.read uncommitted: 读未提交

 3.read committed: 读已提交

4.repaeteble read 可重复读

 5.隔离级别的总结


一.索引

1.索引概念

2.查看索引

show index from course;

3.创建索引

 

create index index_course_name on course(name);

4.索引使用的数据结构是什么

1.HASH(不是)

 

 2.二叉搜索树(不是)

       因为无法降低树的高度 

3.B树   N叉数(不是)

 4.B+树(是滴)

 5.组合索引

针对WHERE


create index index_name_qqemail on student(name,qq_mail);
select * from student where name = '许仙' and qq_mail = 'xuxian@qq.com';

 

 6.索引覆盖

select name,qq_mail from student where name = '许仙' and qq_mail = 'xuxian@qq.com';

7.回表查询

explain select name,qq_mail from student where name = '许仙' and qq_mail = 'xuxian@qq.com';
explain select * from student where qq_mail = 'xuxian@qq.com';

 

8.索引失效

二.事务

1.概念:

事务就是把一组SQL语句打包运行的机制

要么全部都执行成功,要么全都不执行

2.事务的使用

以下列表为例:

1.开启事务:start transaction

2.执行多条SQL语句

3.回滚或者提交:rollback/commit;

rollback即全部失败 ,commit即全部成功

以rollback为例:

在事务还未回滚之前添加以及查询数据结果如下:

 在事务还未回滚之后查询数据结果如下:

可以看到回滚后在事务中添加的数据并未运行成功

3.事务的特性(ACID)

1.原子性

 

 2.一致性

3.隔离性

 

4.持久性

 

4.事务的隔离级别

1.多个事务之间是否会相互影响

2.read uncommitted: 读未提交

脏读是指用户第一次读到了事务没有提交的数据,当事务回滚之后,再次查询发现没有这条数据了

 图例如下:

 那么我们怎么解决这个问题呢?

答案就是加锁

但是写锁解决了脏读的问题,并不能解决重复读的问题

 3.read committed: 读已提交

此时产生了新的问题,不可重复读

不可重复读是指在开启一个事务后,两个相同的查询结果出现了不同的现象

 图例如下:

 

 那么我们怎么解决这个问题呢?

答案还是加锁,不过这次加的是读锁

4.repaeteble read 可重复读

这样就解决了不可重复读的问题

 图例如下:

 

 serializable的隔离级别解决了这个问题,但随之而来性能也降到了最低

 5.隔离级别的总结

说明:MySQL已经很好地解决了 repaeteble read 可重复读 隔离级别下产生的幻读问题,所以我们可以放心使用

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

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

相关文章

Docker Compose与Docker Swarm的简介和区别,以及docker swarm的简单使用命令

Docker Compose与Docker Swarm的简介和区别 背景Compose 简介Swarm 简介Compose 和 Swarm区别docker swarm简单使用及常用命令背景:初始化集群节点加入启动docker程序,nginx服务1.22版本查看服务服务伸缩删除service服务创建密钥secret查看secret使用sec…

清徐乡村e镇助力醋企惊艳亮相全国糖酒会

陈醋香醇悠悠,美味酸爽袭人。4月12日至14日,第108届全国糖酒商品交易会在成都举行,其间启动“山西老陈醋专业镇成都行”,208家山西醋企首次集中亮相交易会,为山西醋代言,由阿里云创新中心运营的清徐乡村e镇…

操作系统概述和体系结构

操作系统的概念和功能 核心:作为系统资源的管理者 向上提供方便易用的服务 联机就好比问一句答一句;脱机就好比先问好多句然后统一依次回答。 上面是直接提供给用户使用的。 另外还有一种程序接口: 这就是程序员在编程时经常调用的各种函数接…

【Linux】3、Linux 的编辑器

目录 一、vi 和 vim二、vim(vi)的三种工作模式(1) 命令模式快捷键(2) 底线命令模式操作 一、vi 和 vim 🔖 vim 和 vi 是 Linux 中经典的文本编辑器 🔖 vim 是 vi 的加强版 🔖 vim: ① 兼容 vi 的全部指令…

(数字图像处理MATLAB+Python)第五章图像增强-第六节:其他图像增强技术

文章目录 一:基于对数图像处理模型的图像增强(1)对数图像处理模型(LIP)(2)基于对数图像处理模型的增强 二:图像去雾增强(1)图像去雾模型(2&#x…

Flutter 布局探索 | 如何分析尺寸和约束

theme: cyanosis 前言 本文来分享一下,通过查看源码和布局信息解决的一个实际中的布局小问题,也希望通过本文的分享,当你遇到布局问题时,可以靠自己的脑子和双手解决问题。 如下所示,将 TextField 作为 AppBar 组件的 …

java版本工程项目管理系统平台源码,助力工程企业实现数字化管理

鸿鹄工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离构建工程项目管理系统 1. 项目背景 一、随着公司的快速发展,企业人员和经营规模不断壮大。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性,公司对内部工程管…

重塑元宇宙体验!元宇宙实时云渲染解决方案来了

元宇宙作为人工智能、云计算和数字孪生等前沿技术的结合体,近年来越发受到各大企业重视。 元宇宙的应用场景层出不穷,不仅包括营销推广场景,还有品牌活动和电商销售,能有效提升品宣和商业转化效果。 元宇宙也具有极大的建设价值…

2.Spring Security详细使用

目录 1. Spring Security详细介绍 2. Spring Security详细使用 3. Spring Security实现JWT token验证 4. JWT(JSON Web Token,JSON令牌) 5. Spring Security安全注解 认证流程 1.集中式认证流程 (1)用户认证 使用…

【Unity入门】15.鼠标输入和键盘输入

【Unity入门】鼠标输入和键盘输入 大家好,我是Lampard~~ 欢迎来到Unity入门系列博客,所学知识来自B站阿发老师~感谢 (一)监听鼠标输入 (1) Input类 Unity的Input类提供了许多监听用户输入的方法,比如我们常见的鼠标&a…

redis复制的设计与实现

一、复制 1.1旧版功能的实现 旧版Redis的复制功能分为 同步(sync)和 命令传播。 同步用于将从服务器更新至主服务器的当前状态。命令传播用于 主服务器状态变化时,让主从服务器状态回归一致。 1.1.1同步 当客户端向服务端发送slaveof命令…

5款十分小众的软件,知道的人不多但却很好用

今天推荐5款十分小众的软件,知道的人不多,但是每个都是非常非常好用的,有兴趣的小伙伴可以自行搜索下载。 1.视频直播录制——OBS Studio OBS Studio可以让你轻松地录制和直播你的屏幕、摄像头、游戏等内容。你可以使用OBS Studio来创建多种…

opengl入门之创建窗口

OpenGL系列文章目录 文章目录 OpenGL系列文章目录前言GLFWGLFW Logo构建GLFWAttention编译生成的库CMake编译我们的第一个工程链接Windows上的OpenGL库Linux上的OpenGL库ImportantGLAD配置GLAD 附加资源 前言 注意,由于作者对教程做出了更新,之前本节使…

springboot使用jasper实现报表demo

概述 业务中尝尝需要用到报表数据的渲染和导出.报表的配置势必不能写死,需要动态配置。 现成的JasperReports Jaspersoft Studio即可实现可配置的报表。 报表布局Jaspersoft Studio https://community.jaspersoft.com/community-download 下载布局工具&#xf…

【fisco-bcos底层链】WeBASE管理平台各组件分别打包成镜像部署到k8s上亲测完成

【fisco-bcos底层链】WeBASE管理平台各组件分别打包成镜像部署到k8s上亲测完成 前言第一步、docker 打包dockerfile书写第二步、fisco-bcos 三节点的底层链1. 更改数据库连接信息2.删除节点中运行预语句中最后的的&符号3. 具体编译的dockerfile4. 编译dockerfile生成 fisco…

【Linux编程Shell自动化脚本】01 Shell 变量、条件语句及常用概念操作等详解

文章目录 一、简介二、变量详解1. 系统变量 三、If条件语句1. ()、(())、[]、[[]]、let和test的区别(1)bash中的Compound Commands(2)Shell Builtin Commands(3)Arithmetic Evaluation(4&#x…

【MySQL | 进阶篇】09、MySQL 管理及常用工具(mysqladmin、mysqlbinlog、mysqldump 等)的使用

目录 一、系统数据库 二、常用工具 2.1 mysql 示例 2.2 mysqladmin 示例 2.3 mysqlbinlog 示例 2.4 mysqlshow 示例 2.5 mysqldump(数据备份) 示例 2.6 mysqlimport/source(数据恢复) 2.6.1 mysqlimport 2.6.2 …

实现表格可编辑(点击字段出现输入框)vue elementUI

实现表格可编辑 参考&#xff1a;el-table 中实现表格可编辑_el表格编辑_快乐征途的博客-CSDN博客 按行保存数据&#xff0c;每行数据最后都有一个保存按钮&#xff0c;如下图所示 使用的是<template>嵌套<el-input> 完整代码如下&#xff1a; <template>…

【计算机视觉 | 目标检测】RT-DETR:DETRs Beat YOLOs on Real-time Object Detection

文章目录 一、前言二、简介三、相关方法3.1 实时目标检测器3.2 端到端目标检测器3.3 目标检测的多尺度特征 四、检测器端到端速度4.1 分析NMS4.2 端到端速度基准 五、The Real-time DETR5.1 方法概览5.2 高效混合编码器5.2.1 计算瓶颈分析5.2.2 Hybrid design5.2.3 IoU-Aware查…

【LeetCode】105. 从前序与中序遍历序列构造二叉树

1.问题 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根节点。 示例 1 输入: preorder [3,9,20,15,7], inorder [9,3,15,20,7] 输出: [3,9,20,null,null…