sql server 嵌套查询语句中什么时候用in,什么时候又用exists!

 我来答
小傻

推荐于2016-06-18 · 知道合伙人软件行家
小傻
知道合伙人软件行家
采纳数:11567 获赞数:31134
已经做过两个上架的app和两个网页项目.

向TA提问 私信TA
展开全部

sqlserver嵌套查询语句中使用in或者exists的场景和原则如下:

  1. 如果查询的两个表大小相当,那么用in和exists差别不大。两者都可以使用。

  2. in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。所以当有多重循环,使用in更合适,效率越高。

  3. 如果两个表中一个较小,一个是大表,则子查询表大的用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是否在(..,...,...)当中
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式