MySQL8新增降序索引
桃花塢里桃花庵,桃花庵里桃花仙,桃花仙人種桃樹,又摘桃花賣酒錢,
一、MySQL5.7 降序索引
MySQL在語法上很早就已經支持降序索引,但實際上創建的卻仍然是升序索引,如下MySQL 5.7 所示,row2欄位降序,但是從show create table看 row2 仍然是升序的,
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
這種情況下只需要掃描 5 行資料:
explain select row1, row2 from t_desc_index order by row1 desc , row2 desc limit 5 ;
綜上可知,MySQL8新增降序索引后可以真正意義上的增加查詢效率,
桃花塢里桃花庵 桃花庵里桃花仙 桃花仙人種桃樹 又摘桃花賣酒錢
轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/470671.html
標籤:MySQL