1. 支持降序索引
降序索引以降序存储键值.虽然在语法上,从MySQL4版本已经支持降序索引的语法了,但实际上该DESC定义是被忽略的.知道MySQL8.x版本才开始真正支持降序索引.(仅限于InnoDB存储引擎).
MySQL在8.0版本前创建的仍然是升序索引,使用时进行反向扫描,大大降低了数据库的效率.在某些场景下,降序索引的意义重大(反向存储,正向扫描,效率高).例如,一个查询需要对多个列进行排序,且顺序要求不一致,那么使用降序索引将避免数据库使用额外的文件排序操作,从而提高性能.
CREATE TABLE demo5(
a INT,
b INT,
INDEX demo5_index(a ASC, b DESC)
)
show index from demo5;
2. 隐藏索引
在MySQL5.7以前,只能通过显式的方式删除索引.此时,如果发现删除的索引后出现错误,又只能通过显式创建索引的方式将删除的索引创建回来.如果数据表的数据量非常大的话,或者数据表本身很大,这种操作会消耗系统过多的资源,操作成本非常高.
从MySQL8.0开始支持隐藏索引.只需要将索引设置为隐藏索引,使查询优化器不再使用这个索引(即使使用force index强制使用索引,优化器也不会使用),确定索引设置为隐藏后系统不受任何响应,就可以彻底删除索引.这种通过将索引设置为隐藏索引