MySQL 新建索引中的 Order 为 ASC 或者 DESC 的区别

更新日期: 2019-03-12 阅读次数: 658 字数: 205 分类: MySQL

在使用 MySQL Workbench 新建 MySQL 数据表索引时,会看到 Order 这一项配置。

可选值为 ASC 或者 DESC。

MySQL 新建索引中的 Order 为 ASC 或者 DESC 的区别

对应的建表语句为

CREATE TABLE `blog`.`products` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(255) NOT NULL,
  `status` TINYINT NOT NULL DEFAULT 1,
  PRIMARY KEY (`id`),
  INDEX `ix_status` (`status` ASC))
ENGINE = InnoDB
DEFAULT CHARACTER SET = utf8mb4;

可以看到 INDEX 默认为 ASC。

MySQL 5.7 及之前版本

索引的默认 Order 为 ASC,即使指定为 DESC 在数据存储时也是 ASC。所以,索引 Order 只是为了方便未来扩展所预留的一个关键字。在 MySQL 5.7 及之前版本中,并不起任何作用。

MySQL 8.0 及之后版本

MySQL 是在 8.0 之后支持了 Order 为 DESC。这样就有效提示了倒序的查询速度。

参考

爱评论不评论

近期节日

2019年05月20日 全国助残日
2019年05月21日 小满
2019年05月30日 五卅运动纪念
2019年05月31日 世界无烟日
2019年06月01日 六一儿童节
2019年06月05日 世界环境日
2019年06月06日 芒种
2019年06月06日 全国爱眼日
2019年06月07日 端午节
2019年06月11日 中国人口日
2019年06月16日 父亲节
2019年06月20日 世界难民日
查看更多节日