select * from t_sku s where EXISTS(select 1 from t_resource r where r.title = "QUEEN'S PALACE高级定制馆1-自动化" and s.resource_id = r.id) ;
等同于 :
SELECT * FROM t_sku t WHERE t.resource_id IN (SELECT r.id FROM t_resource r WHERE r.title = "QUEEN'S PALACE高级定制馆1-自动化");
例如上面的sql,使用了EXISTS进行查询!
1、exists的返回结果是bool型,只有true或者false
2、exists的效率比in查询要高,in适合的情况是外表数据量小的情况,而不是外表数据大的情况,因为in会遍历外表的全部数据,假设a表100条,b表10000条那么遍历次数就是100*10000次,而exists则是执行100次去判断a表中的数据是否在b表中存在,它只执行了a.length次数,至于哪一个效率高是要看情况的,因为in是在内存中比较的,而exists则是进行数据库查询操作的。
网友评论