MYSQL IN 与 EXISTS 的优化示例介绍
优化原则:小表驱动大表,即小的数据集驱动大的数据集。
#############原理(RBO)#####################
select*fromAwhereidin(selectidfromB) 等价于: forselectidfromB forselect*fromAwhereA.id=B.id
当B表的数据集必须小于A表的数据集时,用in优于exists。
select*fromAwhereexists(select1fromBwhereB.id=A.id) 等价于 forselect*fromA forselect*fromBwhereB.id=A.id
当A表的数据集系小于B表的数据集时,用exists优于in。
注意:A表与B表的ID字段应建立索引。
例如:
/**执行时间:0.313s**/ SELECTSQL_NO_CACHE*FROMrocky_membermWHEREEXISTS(SELECT1FROMrocky_vip_approaWHEREm.ID=a.user_idANDa.passed=1); /**执行时间:0.160s**/ SELECTSQL_NO_CACHE*FROMrocky_membermWHEREm.IDin(SELECTIDFROMrocky_vip_approWHEREpassed=1);
notin和notexists用法类似。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短