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

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

mysql innodb 索引查詢的一個疑問?

mysql innodb 索引查詢的一個疑問?

人到中年有點甜 2018-10-24 18:49:39
假設有這么個sql查詢 select * from table where id=xxxx order by time這張table上有兩個索引,一個是id聚集索引,還有一個是time非聚集索引。那么我們假設強制它走time非聚集索引,那么執(zhí)行這個sql的第一步就是直接把排序好的葉子節(jié)點拿出來。這個葉子節(jié)點的data域存放的是主鍵名,即id。那么問題來了,接下來要匹配where條件了,是直接在time索引的葉子節(jié)點的data域上來where匹配id,還是拿到id再去通過主鍵索引拿到行數據來where匹配id呢?思考:select * from table where time=xxxx order by time ,會怎么樣?如果上面那個問題的答案是前者(直接在time索引的葉子節(jié)點的data域上來where匹配id),那這句sql和上面那句sql的查詢效率應該是差不多的?
查看完整描述

1 回答

?
HUH函數

TA貢獻1836條經驗 獲得超4個贊

怎么查看你查什么
第一條sql會在time索引找到滿足where條件的id,然后拿著id去主鍵聚集獲取其他字段
第二條同樣是在time索引上找到滿足where條件的id,然后再去獲取其他數據
不同的是,第一種情況會遍歷所有的time索引段,第二種只需要檢索滿足條件的time索引段即可

查看完整回答
反對 回復 2018-10-24
  • 1 回答
  • 0 關注
  • 520 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號