15、联合索引是什么?为什么需要注意联合索引中的顺序?

联合索引是什么?为什么需要注意联合索引中的顺序?

MySQL可以使用多个字段同时建立一个索引,叫做联合索引。在联合索引中,如果想要命中索引,需要按照建立索引时的字段顺序挨个使用,否则无法命中索引。

具体原因为:

MySQL使用索引时需要索引有序,假设现在建立了"name,age,school"的联合索引,那么索引的排序为: 先按照name排序,如果name相同,则按照age排序,如果age的值也相等,则按照school进行排序。

当进行查询时,此时索引仅仅按照name严格有序,因此必须首先使用name字段进行等值查询,之后对于匹配到的列而言,其按照age字段严格有序,此时可以使用age字段用做索引查找,以此类推。因此在建立联合索引的时候应该注意索引列的顺序,一般情况下,将查询需求频繁或者字段选择性高的列放在前面。

此外可以根据特例的查询或者表结构进行单独的调整。

相关推荐
沃尔威武4 小时前
数据库 Sinks(.net8)
数据库·.net·webview
Dreamboat¿5 小时前
SQL 注入漏洞
数据库·sql
曹牧5 小时前
Oracle数据库中,将JSON字符串转换为多行数据
数据库·oracle·json
被摘下的星星6 小时前
MySQL count()函数的用法
数据库·mysql
末央&6 小时前
【天机论坛】项目环境搭建和数据库设计
java·数据库
徒 花6 小时前
数据库知识复习07
数据库·作业
素玥6 小时前
实训5 python连接mysql数据库
数据库·python·mysql
jnrjian6 小时前
text index 查看index column index定义 index 刷新频率 index视图
数据库·oracle
瀚高PG实验室7 小时前
审计策略修改
网络·数据库·瀚高数据库
言慢行善7 小时前
sqlserver模糊查询问题
java·数据库·sqlserver