sql--索引使用 ---覆盖索引

覆盖索引

Select 后接 * 走id索引才是最优,使用二级索引则需要回表(性能稍差)

前缀索引

Create index 索引名 on 表名( 字段名( n ) )

n数字 n代表提取这个字符串的n个构建索引

??那么 n 为几性能是最好的呢?

distinct 去重

Count 统计

Select count(*)from tb_user -- 总数量

Select count( distinct email)from tb_user -- 去重后数量

图片是去重 email 前五位相同的 数量

计算选择性

字段去重后数量/字段总数 = 1 选择性越接近1 或等于1 是选择性是最好的

单列索引与联合索引的选择

Select id, phone,name from tb_user where phone = '17799990010' and name = '韩信'

Elplain查看执行计划 phone和name都是单列索引,只走了一个索引

Select 需要的数据为 id, phone,name

Extra 为null 代表需要回表查询

单列索引--不涉及覆盖查询,叶子节点只有phone 和 id 需要回表才能得到name

创建联合索引 创建唯一索引关键字 unique

Create unique index 索引名 on 表名(字段名1,字典名2)

创建phone 和 name 的联合索引进行查询

查看执行计划

覆盖查询

更建议建立联合索引--提升效率

索引设计原则

主键索引 唯一索引 常规索引 全文索引 全部分为两类 聚集索引 二级索引

聚集索引肯定存在且只有一个,默认主键索引就是聚集索引,如果没有主键,则默认第一个唯一索引为聚集索引,如果主键和唯一索引都没有则会隐藏的生成rowid作为聚集索

相关推荐
这个DBA有点耶4 分钟前
数据迁移避坑指南:从Oracle到国产数据库的兼容性问题
数据库·数据仓库·sql·oracle·dba
小短腿的代码世界24 分钟前
Qt国际化深度解析:从源码到企业级多语言实践
java·数据库·qt
Ting-yu29 分钟前
Spring AI Alibaba零基础速成(6) ---- 向量化
数据库·人工智能
dishugj1 小时前
HANA性能分析视图
数据库
l1t1 小时前
DeepSeek总结的在 DuckDB 中试驾 Lance 数据湖仓格式
数据库·人工智能·机器学习·duckdb
PaperData2 小时前
2017-2025年中国10米分辨率土地利用/覆盖栅格数据(from Esri LULC)
数据库·数据分析·学习方法
小二·2 小时前
LangGraph 多智能体实战:从零搭建 Multi-Agent 协作系统
java·开发语言·数据库
羑悻的小杀马特2 小时前
工业时序数据选型的几点思考:从存储成本与查询延迟说起
数据库·人工智能
小旭95272 小时前
商品详情实现与缓存问题(穿透、击穿、雪崩)解决方案
java·数据库·spring boot·后端·缓存
我本楚狂人www3 小时前
Spring 两大核心思想(一):IoC
java·数据库·spring