請問下如何在Mysql中where與orderBy後在命中索引?

來源:互聯網
上載者:User
我現在大概有一個需求,是需要在資料庫中查詢一個列表。資料表的樣子大概是這樣的:

A B C D E
1 1 1 2016-08-05 40
... ... ... ... ...

而我現在的SQL語句大概是這樣的

SELECT * FROM `TABLE` WHERE B = 1 AND C = 1 AND D = 2016-08-05 ORDER BY E DESC

在這種情況下我應該怎麼建立索引才能在查詢的時候命中呢?建立index(['B', 'C', 'D', 'E'])的複合索引可以嗎?

回複內容:

我現在大概有一個需求,是需要在資料庫中查詢一個列表。資料表的樣子大概是這樣的:

A B C D E
1 1 1 2016-08-05 40
... ... ... ... ...

而我現在的SQL語句大概是這樣的

SELECT * FROM `TABLE` WHERE B = 1 AND C = 1 AND D = 2016-08-05 ORDER BY E DESC

在這種情況下我應該怎麼建立索引才能在查詢的時候命中呢?建立index(['B', 'C', 'D', 'E'])的複合索引可以嗎?

理論上是可以這麼建的,因為索引的左首碼原則,會依次命中B,C,D三個欄位,但是很遺憾,E欄位只用來排序的話是無法觸發索引的。
因為當order by 欄位出現在where條件中時,才會利用索引而無需排序操作。其他情況,order by不會出現排序操作。
具體可以看這篇文章,分析orderby 和索引的關係
http://www.cnblogs.com/zhaoyl...

mysql 強制指定索引 FORCE INDEX

SELECT * FROM TABLE1 FORCE INDEX (FIELD1) …
以上的SQL語句只使用建立在FIELD1上的索引,而不使用其它欄位上的索引。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.