sqlserver嵌套查询语句中使用in或者exists的场景和原则如下:
如果查询的两个表大小相当,那么用in和exists差别不大。两者都可以使用。
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。所以当有多重循环,使用in更合适,效率越高。
如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in。
NOT EXISTS,exists的用法跟in不一样,一般都需要和子表进行关联,而且关联时,需要用索引,这样就可以加快速度。
判断是否在集合里用in,exists在SQL中的作用:检验查询是否返回数据。举例: 查询users表里id在user_id表id集合中的用户名称select name from users where id in (select id from user_id); 举例:exists返回真假 当 where 后面的条件成立,则列出数据,否则为空select * from tb a where exists(select 1 from tb where name = a.name )
exists() 只要不是空都成立xx in (..,...,...) , xx是否在(..,...,...)当中