mysql索引技术名词1-5
目录
- 索引技术名词
- 1.回表
- 2.覆盖索引
- 3.最左匹配原则
- 4.索引下推
- 5.谓词下推
索引技术名词 1.回表
注意:
1.如果依靠主键查询,叶子结点直接存储数据----主键B+树
2.如果依靠其他健查询查询,叶子结点存储主键值,再通过主键值查询数据。通过主键值查询数据的过程叫做回表----普通B+树字段查找主键,再到主键B+树查询数据
2.覆盖索引
1:select * from table1 where name='zhangsan'
2:select id from table1 where name='zhangsan'第一种必须进行回表查询其他字段数据
第二种,其他健的B+树叶子结点已经存储id值,直接返回,不需要进行回表操作。叫做覆盖索引
3.最左匹配原则
id,name,age,gender
给(name,age)创建了组合索引1:select * from table1 where name='zhangsan'
2:select * from table1 where name='zhangsan' and age=10
3:select * from table1 where age=10
4:select * from table1 where age=10 and name='zhangsan'第1,2,4种用到了组合索引,最左原则。必须先查左边的name,再查右边的age
第4中因为mysql架构在优化器的时候内部会重构执行流程
4.索引下推
(name,age)组合索引,最左原则
正常情况下:
1.先根据name列从存储引擎中把符合规则的数据拉取到mysql的server曾
2.再server层按照age进行数据过滤索引下推情况下:
1.直接从存储引擎拉取数据的时候直接按照name和age做判断,将符合的结果返回给mysql的server层
5.谓词下推
select t1.name,t2.name from t1 join t2 on t1.id=t2.id执行方式:
1:把所有的字段先做表关联,然后再从关联好的表中选择需要的4个字段
2:先把两张表需要的4个字段取出,然后再做表关联结论:很明显使用第二种,减少不必要的数据量
推荐阅读
- IDEA|IDEA 连接MySQL并使用
- MySQL|MySQL 学习-进阶
- MYSQL插入数据时检查字段值是否重复的方法详解
- #|【PCIe 6.0】颠覆性技术!你NRZ相守20年又怎样(看我PAM4如何上位PCIe 6.0 !)
- 技术实践类|BMP280使用指南
- 微信|IM“扫一扫”功能很好做(看看微信“扫一扫识物”的完整技术实现)
- 怎么给字符串字段加索引()
- MySQL|MySQL 学习笔记(二)MVCC 机制
- 数仓建模—ID|数仓建模—ID Mapping - 大数据技术派 - 博客园
- 虚拟存储技术与交换覆盖技术的区别