【MySQL】索引和事务(B树、B+树图解原理)

一、索引

1.1 什么是索引?

索引是一种特殊的文件,包含着对数据表里所有记录的引用指针。可以对表中的一列或多列创建索引,并指定索引的类型,各类索引有各自的数据结构实现。

1.2 索引的作用

🚓(1)数据库中的表、数据、索引之间的关系,类似于书架上的图书、书籍内容和书籍目录的关系。
🚓(2)索引所起的作用类似书籍目录,可用于快速定位、检索数据。
🚓(3)索引对于提高数据库的性能有很大的帮助。

1.3 使用场景

🚗(1)数据量较大,且经常对这些列进行条件查询。
🚗(2)该数据库表的插入操作,及对这些列的修改操作频率较低。
🚗(3)索引会占用额外的磁盘空间。

反之,如果非条件查询列,或经常做插入、修改操作,或磁盘空间不足时,不考虑创建索引。

1.4 索引的相关SQL

🚕(1)查看索引

sql 复制代码
show index from 表名;

🚕(2)创建索引

sql 复制代码
create index 索引名字 on 表名(列名);

🚕(3)删除索引

sql 复制代码
drop index 索引名字 on 表名;

1.5 索引背后的数据结构-B+树

在介绍B+树之前先了解一下B+树的前身B树(也叫B-树)

B+树:

二、事务

2.1 什么是事务?

事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部失败。

2.2 使用事务的目的

为了把若干个独立的操作打包成一个整体

2.3 事物的基本特性:

2.3.1 原子性

我们把要么一起成功(A帐户成功减少1000,同时B帐户成功增加1000),要么一起失败(A帐户回到原来状态,B帐户也回到原来状态)的操作叫原子性操作

2.3.2 一致性

在事务执行之前,和执行之后,数据库中的数据都是合理合法的,数据库不会因事务执行而遭到破坏

2.3.3 隔离性

隔离性是针对数据资源的并发访问,规定了各个事务之间相互影响的程度。

相关推荐
大白要努力!2 分钟前
android 使用SQLiteOpenHelper 如何优化数据库的性能
android·数据库·oracle
tatasix1 小时前
MySQL UPDATE语句执行链路解析
数据库·mysql
南城花随雪。1 小时前
硬盘(HDD)与固态硬盘(SSD)详细解读
数据库
儿时可乖了1 小时前
使用 Java 操作 SQLite 数据库
java·数据库·sqlite
懒是一种态度1 小时前
Golang 调用 mongodb 的函数
数据库·mongodb·golang
天海华兮1 小时前
mysql 去重 补全 取出重复 变量 函数 和存储过程
数据库·mysql
gma9992 小时前
Etcd 框架
数据库·etcd
爱吃青椒不爱吃西红柿‍️2 小时前
华为ASP与CSP是什么?
服务器·前端·数据库
Yz98763 小时前
hive的存储格式
大数据·数据库·数据仓库·hive·hadoop·数据库开发
武子康3 小时前
大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本
java·大数据·数据仓库·hive·hadoop·mysql