sql server 嵌套查询语句中什么时候用in,什么时候又用exists!
3个回答
展开全部
sqlserver嵌套查询语句中使用in或者exists的场景和原则如下:
如果查询的两个表大小相当,那么用in和exists差别不大。两者都可以使用。
in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。所以当有多重循环,使用in更合适,效率越高。
如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in。
NOT EXISTS,exists的用法跟in不一样,一般都需要和子表进行关联,而且关联时,需要用索引,这样就可以加快速度。
2013-12-23
展开全部
判断是否在集合里用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 )
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-12-23
展开全部
exists() 只要不是空都成立xx in (..,...,...) , xx是否在(..,...,...)当中
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询