mysql按升序创建索引 | 您所在的位置:网站首页 › 数据库的升序 › mysql按升序创建索引 |
在 8.0 之前,能够以相反的顺序对索引进行扫描,但是会降低性能,降序索引能够实现相同的效果,且不会损耗性能。另外一个例子,当一个查询 SQL,需要按多个字段,以不同的顺序进行排序时,8.0 之前无法使用索引已排序的特性,因为 order by 的顺序与索引的顺序不一致,而使用降序索引,就能够指定联合索引中每一个字段的顺序,以适应 SQL 语句中的 order by 顺序,让 SQL 能够充分使用索引已排序的特性,提升 SQL 性能。 来看一个例子,表结构如下: CREATE TABLE t ( c1 INT, c2 INT, INDEX idx1 (c1 ASC, c2 ASC), INDEX idx2 (c1 ASC, c2 DESC), INDEX idx3 (c1 DESC, c2 ASC), INDEX idx4 (c1 DESC, c2 DESC) ); 表中有两个字段,c1 和 c2,根据 c1,c2 的不同顺序的组合,创建了 4 个索引,由于索引字段的排序不同,因此对于不同的 order by 顺序,优化器可以使用的索引也不相同,如果 order by 顺序与索引字段的顺序一致,那么就可以避免额外的 filesort ,从而提升性能。 ORDER BY c1 ASC, c2 ASC -- 优化器选择使用 idx1 ORDER BY c1 DESC, c2 DESC -- 优化器选择使用 idx4 ORDER BY c1 ASC, c2 DESC -- 优化器选择使用 idx2 ORDER BY |
CopyRight 2018-2019 实验室设备网 版权所有 |