《Mysql學習MYSQL IN 與 EXISTS 的優(yōu)化示例介紹》要點:
本文介紹了Mysql學習MYSQL IN 與 EXISTS 的優(yōu)化示例介紹,希望對您有用。如果有疑問,可以聯(lián)系我們。
優(yōu)化原則:小表驅動年夜表,即小的數(shù)據(jù)集驅動年夜的數(shù)據(jù)集.MYSQL入門
############# 原理 (RBO) #####################
MYSQL入門
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表的數(shù)據(jù)集必需小于A表的數(shù)據(jù)集時,用in優(yōu)于exists.MYSQL入門
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表的數(shù)據(jù)集系小于B表的數(shù)據(jù)集時,用exists優(yōu)于in.MYSQL入門
注意:A表與B表的ID字段應建立索引.MYSQL入門
例如:MYSQL入門
/** 執(zhí)行光陰: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); /** 執(zhí)行光陰: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用法類似.MYSQL入門
《Mysql學習MYSQL IN 與 EXISTS 的優(yōu)化示例介紹》是否對您有啟發(fā),歡迎查看更多與《Mysql學習MYSQL IN 與 EXISTS 的優(yōu)化示例介紹》相關教程,學精學透。維易PHP學院為您提供精彩教程。
轉載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/8067.html