文章詳情頁
mysql order by為什么沒有走索引排序?
瀏覽:143日期:2022-06-13 13:04:11
問題描述
order by city_id (主鍵走索引)
order by country_id(不走索引!!!)
問題解答
回答1:你的city_id是主鍵,而country_id是復合主鍵。
回答2:改成
SELECT * FROM city FORCE INDEX(idx_fk_country_id) ORDER BY country_id;
是這樣的,你在SELECT中查詢了索引建以外的列,那么ORDER BY就不會使用索引了。你可以用FORCE INDEX來強制使用索引。
還有一點,就是所謂的覆蓋索引。覆蓋索引的定義是:MySQL可以根據(jù)索引返回select字段而不用根據(jù)索引再次查詢文件而得出結(jié)果。
當你使用select *時,你沒有強制指定索引,那么mysql為了得到你的查詢的字段而查詢文件,然后再進行排序操作,這就沒有用到覆蓋索引。而你使用了force index就會強制使用覆蓋索引,這樣就不會出現(xiàn)filesort的情況了。
回答3:相關(guān)文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現(xiàn)存在即更新應該使用哪個標簽?2. 哭遼 求大佬解答 控制器的join方法怎么轉(zhuǎn)模型方法3. mysql儲存json錯誤4. mysql - 怎么生成這個sql表?5. mysql - 數(shù)據(jù)庫表中,兩個表互為外鍵參考如何解決6. Navicat for mysql 中以json格式儲存的數(shù)據(jù)存在大量反斜杠,如何去除?7. sql語句 - 如何在mysql中批量添加用戶?8. mysql - 表名稱前綴到底有啥用?9. 編輯成功不顯示彈窗10. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。
排行榜

熱門標簽