MYSQL IN 與 EXISTS 的優化示例引見。本站提示廣大學習愛好者:(MYSQL IN 與 EXISTS 的優化示例引見)文章只能為提供參考,不一定能成為您想要的結果。以下是MYSQL IN 與 EXISTS 的優化示例引見正文
優化准繩:小表驅動年夜表,即小的數據集驅動年夜的數據集。
############# 道理 (RBO) #####################
select * from A where id in (select id from B) 等價於: for select id from B for select * from A where A.id = B.id
當B表的數據集必需小於A表的數據集時,用in優於exists。
select * from A where exists (select 1 from B where B.id = A.id) 等價於 for select * from A for select * from B where B.id = A.id
當A表的數據集系小於B表的數據集時,用exists優於in。
留意:A表與B表的ID字段應樹立索引。
例如:
/** 履行時光:0.313s **/ SELECT SQL_NO_CACHE * FROM rocky_member m WHERE EXISTS (SELECT 1 FROM rocky_vip_appro a WHERE m.ID = a.user_id AND a.passed = 1); /** 履行時光:0.160s **/ SELECT SQL_NO_CACHE * FROM rocky_member m WHERE m.ID in(SELECT ID FROM rocky_vip_appro WHERE passed = 1);
not in 和not exists用法相似。