第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請教各位一個問題,求解答:MySQL覆蓋索引時允許索引執(zhí)行LIKE操作嗎?跪求!

請教各位一個問題,求解答:MySQL覆蓋索引時允許索引執(zhí)行LIKE操作嗎?跪求!

Qyouu 2019-08-24 22:09:12
問題描述:學習時,p172舉例explainselect*fromproductsfromactor='SEANCARREY'andtitlelike'%APOLLO%',解釋這里索引無法覆蓋該查詢的原因其中第二個是:MySQL不能在索引中執(zhí)行LIKE操作.但是我實際發(fā)現(xiàn),即使索引執(zhí)行了LIKE也是可以覆蓋索引的!演示代碼:--基于MySQL版本:8.0.16--創(chuàng)建一個只有2個字段的表droptableifexistsproducts;createtableproducts(actorvarchar(20),titlevarchar(20));--創(chuàng)建覆蓋所有字段的索引,并未指定索引長度createindexidx_actor_titleonproducts(actor,title);--索引執(zhí)行LIKE操作,查看explain結(jié)果explainselect*fromproductswhereactor='SEAN'andtitlelike'%APOLLO%';執(zhí)行結(jié)果是:Extra是Usingwhere;Usingindex,所以說即使執(zhí)行了LIKE也還是覆蓋索引請問是MySQL版本的問題嗎,還是我的理解有問題?感謝!
查看完整描述

2 回答

?
蝴蝶刀刀

TA貢獻1801條經(jīng)驗 獲得超8個贊

覆蓋索引是因為表字段就2個,都被索引包含,但只用到了索引第一列actor,可以查看EXPLAIN的ref字段,只有一個const
                            
查看完整回答
反對 回復 2019-08-24
?
素胚勾勒不出你

TA貢獻1827條經(jīng)驗 獲得超9個贊

覆蓋索引采用b+tree,上層是actor,actor子葉是title,所以判斷是采用了索引。
like是可以采用索引的,如果你用b+tree,可以用like'AP%',這樣規(guī)定字段開頭是可以命中b+bree,因為b+tree本來就是按照順序存儲。
ps:并不是所有的like都是洪水猛獸!
                            
查看完整回答
反對 回復 2019-08-24
  • 2 回答
  • 0 關注
  • 230 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號