日期:2014-05-17  浏览次数:20878 次

问个exists的问题。。。
其实我就是想弄明白下面两个SQL语句的差别,希望大大们指点指点:
SQL 1:
select t.id, t.name from t_user_info t where exists (select 1 from t_res_code c where t.id=c.userid)


SQL 2:
select t.id, t.name from t_user_info t where (select count(0) from t_res_code c where t.id=c.userid)>0

Oracle SQL exists

------解决方案--------------------
我觉得sql1比sql2效率要高很多
------解决方案--------------------
你可以看看执行计划
你从执行计划里面就可以看出来
------解决方案--------------------
不同的表和结构 2个sql 执行效率都是不同的 看执行计划比较直观