如何给mysql创建组合索引并分析索引命中(官方校正版)

MySQL 可以使用多列索引来执行测试索引中所有列的查询,或者仅测试第一列、前两列、前三列等的查询。如果您在索引定义中以正确的顺序指定列,则单个复合索引可以加速同一表上的几种查询。

MySQL 可以创建复合索引(即在多个列上建立索引)。索引最多可包含 16 个列。

对于某些数据类型,您可以索引列的前缀。

多列索引可以被视为一个排序数组,其行包含通过连接索引列的值而创建的值。

以下语句可以通过命令行操作,如需要SQL工具可以试用SQLynx或MySQL workbench等

作为复合索引的替代方法,您可以引入一个基于其他列的信息进行"散列"的列。如果此列很短、相当唯一且已编入索引,则它可能比在许多列上建立"宽"索引更快。在 MySQL 中,使用此额外列非常容易:

language-sql 复制代码
SELECT * FROM tbl_name
  WHERE hash_col=MD5(CONCAT(val1,val2))
  AND col1=val1 AND col2=val2;

假设有一张表具有以下规格:

language-sql 复制代码
CREATE TABLE test (
    id         INT NOT NULL,
    last_name  CHAR(30) NOT NULL,
    first_name CHAR(30) NOT NULL,
    PRIMARY KEY (id),
    INDEX name (last_name,first_name)
);

索引是和列name的索引 。索引可用于在指定已知范围内的值的查询中查找 和 值的组合。它还可以用于仅指定值的查询, 因为该列是索引的最左前缀(如本节后面所述)。因此,索引用于以下查询中的查找: last_name``first_name``last_name``first_name``last_name``name

language-sql 复制代码
SELECT * FROM test WHERE last_name='Jones';

SELECT * FROM test
  WHERE last_name='Jones' AND first_name='John';

SELECT * FROM test
  WHERE last_name='Jones'
  AND (first_name='John' OR first_name='Jon');

SELECT * FROM test
  WHERE last_name='Jones'
  AND first_name >='M' AND first_name < 'N';

但是,name索引 用于以下查询中的查找:

language-sql 复制代码
SELECT * FROM test WHERE first_name='John';

SELECT * FROM test
  WHERE last_name='Jones' OR first_name='John';

假设您发出以下 SELECT语句:

language-sql 复制代码
SELECT * FROM tbl_name
  WHERE col1=val1 AND col2=val2;

col1如果和 上存在多列索引col2,则可直接提取相应的行。如果 和 上存在单独的单列索引 col1,则col2优化器将尝试使用索引合并优化(请参见 第 10.2.1.3 节"索引合并优化"),或者尝试通过确定哪个索引排除更多行并使用该索引提取行来找到最严格的索引。

如果表具有多列索引,则优化器可以使用索引的任何最左前缀来查找行。例如,如果您在 上有一个三列索引,则您具有对、和 的 (col1, col2, col3)索引搜索功能 。 (col1)(col1, col2)(col1, col2, col3)

如果列不构成索引的最左前缀,则 MySQL 无法使用索引执行查找。假设您有SELECT如下所示的语句:

sql 复制代码
SELECT * FROM tbl_name WHERE col1=val1;
SELECT * FROM tbl_name WHERE col1=val1 AND col2=val2;

SELECT * FROM tbl_name WHERE col2=val2;
SELECT * FROM tbl_name WHERE col2=val2 AND col3=val3;

如果 上有索引(col1, col2, col3),则只有前两个查询会使用索引。第三和第四个查询确实涉及索引列,但不使用索引来执行查找,因为(col2)(col2, col3)不是的最左前缀 (col1, col2, col3)

相关推荐
树谷-胡老师1 小时前
公元前3400年至公元2024年全球国家地理边界演变数据集
数据库·arcgis·信息可视化
疯狂的Alex1 小时前
2010-2022 同等学力申硕国考:软件工程简答题真题汇总
数据库·oracle·软件工程
Qlittleboy1 小时前
tp5的tbmember表闭包查询 openid=‘abc‘ 并且(wx_unionid=null或者wx_unionid=‘‘)
数据库·sql·php
markfeng81 小时前
一文搞懂MySQL字符集
sql·mysql
躲在云朵里`1 小时前
Spring Scheduler定时任务实战:从零掌握任务调度
java·数据库·mybatis
小白不想白a2 小时前
【MySQL】常用SQL语句
数据库·sql·mysql
RestCloud2 小时前
从MySQL到StarRocks:全量与增量同步的最佳实践
数据库·mysql·api
Databend2 小时前
Databend 八月月报:向量检索重磅上线,性能飞跃几十倍
数据库
毕设源码纪师姐3 小时前
计算机毕设 java 高校机房综合管控系统 基于 SSM+Vue 的高校机房管理平台 Java+MySQL 的设备与预约全流程系统
java·mysql·课程设计
路弥行至3 小时前
从0°到180°,STM32玩转MG996R舵机
c语言·数据库·stm32·单片机·嵌入式硬件·mcu·mongodb