文章詳情頁
mysql優化 - mysql 模糊查詢和order by同用如何建立索引?
瀏覽:104日期:2022-06-11 13:49:18
問題描述
比如現在有這樣一個mysql語句:
select * from city where city_name like ’%hf%’ order by created_at;
這樣的sql語句如何建立索引呢,如果是建立復合索引,使用:
key(created_at,city_name)
這個由于created_at在前面,根據索引的最左匹配原則退化成了key(created_at).
key(city_name,created_at)
肯定也不行,前面是模糊查詢,這個復合索引退化成了key(city),那么這種情況只能建立單個的索引列來解決問題嗎?請教各位大大.
問題解答
回答1:前后都是%是不走索引的,都沒有索引退化的問題,要么改sql成前綴匹配要么加全文索引(對于短字串并不合適),再有就是對于這種基本不變的數據在應用里面是可以放到搜索引擎里的,可以利用到它的分詞器檢索
相關文章:
1. Python列表或者字典里面的中文如何處理?2. javascript - vue router 怎么實現某個頁面禁止瀏覽器回退?3. javascript - ES6 Module可以直接導入commonJS的模塊, 這個是ES6直接就實現了的, 還是babel轉的時候實現的?4. javascript - 【快速判斷數組為空】[]==false 為什么返回true?5. javascript - 關于JS 事件委托操作ul li標簽的問題6. javascript - 關于禁用文本選擇與復制的問題7. javascript - html 表單如何恢復8. javascript - 請問,jquery中創建新節點之后插入之后再給這個節點添加css樣式,可以一句話寫完么?9. javascript - 讀js權威指南“作為值得函數”產生了疑惑,求釋疑10. css3 - css做動畫效果
排行榜
