您的位置:首页 > 其它

Select语句查询中in和exists的区别

2012-10-15 19:32 381 查看
in是关系运算符,确定给定的值是否与子查询中的值或列表中的值相匹配;exists是相关子查询,是用来判断括号里面的值或者结果集是否为null的,返回的是bit类型的。

这里值得强调的是exists的效率比in高的说法是不正确的,应该具体问题具体分析。

in可以分为三类:

1、形如:select * from t1 where f1 in ( 'a', 'b ')

2、形如 :select * from t1 where f1 in (select f1 from t2where t2.fx= 'x '),

其中子查询的where里的条件不受外层查询的影响,这类查询一般情况下,自动优化会转成exist语句,也就是效率和exist一样。

3、形如:select * from t1 where f1 in (select f1 from t2where t2.fx=t1.fx),

其中子查询的where里的条件受外层查询的影响,这类查询的效率要看相关条件涉及的字段的索引情况和数据量多少,一般认为效率不如exists。

除了第一类in语句都是可以转化成exists 语句的,并且一般编程习惯应该是用exists而不用in.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: