MySQL8新增降序索引

MySQL8新增降序索引

 

  桃花塢裏桃花庵,桃花庵裏桃花仙。桃花仙人種桃樹,又摘桃花賣酒錢。

 

一、MySQL5.7 降序索引

MySQL在語法上很早就已經支持降序索引,但實際上創建的卻仍然是升序索引,如下MySQL 5.7 所示,row2字段降序,但是從show create table看 row仍然是升序的。

CREATE TABLE t_desc_index ( row1 INT, row2 INT, INDEX idx_row1_row2 ( row1, row2 DESC ) );

SHOW CREATE TABLE t_desc_index 

二、MySQL8 降序索引

在MySQL8中,以同樣的方式創建降序索引row2,show create table查看。

SHOW CREATE TABLE t_desc_index\G 看到 KEY ‘idx_row1_row2’(‘row1’,’row2’ DEDC)

8.0中可以看到,row2字段降序,此時爲降序索引。

三、新增降序索引有何好處?

通過降序索引在執行計劃中的表現,在 t_desc_index 表插入10萬條隨機數據,在通過 explain 查看各自版本的執行計劃。

1、數據準備

插入99999條隨機數據,存儲過程

CREATE PROCEDURE insert_t_desc_index ( ) BEGIN
DECLARE
    i INT DEFAULT 1;
WHILE
    i < 100000 DO
    INSERT INTO t_desc_index SELECT
    rand( ) * 100000,
    rand( ) * 100000;

SET i = i + 1;

END WHILE;
COMMIT;
END;

調用存儲過程插入數據。

CALL insert_t_desc_index ( );

2、測試

查詢五條數據,根據索引 idx_row1_row2 按照降序順序排序。

explain select row1, row2 from t_desc_index order by row1 , row2 desc limit 5;

從 explain 解釋可以看出,查詢五條數據,需要掃描96491 行數據,並且使用了filesort

降序索引只是對查詢中特定的排序順序有效,即升序索引降序排序反無效,降序索引升序排序無效。如果使用不當,反而查詢效率更低,比如上述查詢排序條件改爲

order by c1 desc, c2 desc

這種情況下只需要掃描 行數據

explain select row1, row2 from t_desc_index order by row1 desc , row2  desc limit 5 ;

綜上可知,MySQL8新增降序索引後可以真正意義上的增加查詢效率。

 

 

 

桃花塢裏桃花庵
桃花庵裏桃花仙
桃花仙人種桃樹
又摘桃花賣酒錢

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章