SQL中EXISTS和IN用法

SQLEXISTS的用法  

指定一个子查询,检测行的存在。

语法:EXISTS subquery

参数:subquery

是一个受限的 SELECT 语句 (不允许有 COMPUTE 子句和 INTO 关键字)。  

结果类型:Boolean

结果值:如果子查询包含行,则返回 TRUE。否则返回False

 

select  Resc_id  from  dbo.Res_Coach

where  EXISTS (select * from  Res_Coach  where  Resc_id  is  null)

 

查询原理:

遍历dbo.Res_Coach每一条,同时处理where条件(EXISTS (select * from Res_Coach where Resc_id=0) 判断结果为true或者false),为true时拿出该条,false时,放弃该条记录。

 

1)  where条件中的子查询和主查询没关系

select  Resc_id

from  dbo.Res_Coach

where  EXISTS (select  Rese_id  from  dbo.Res_Excellent  where  Rese_id  Is  null )

 

2)  where条件中得子查询和主查询有关系

select  Resc_id

from  dbo.Res_Coach

where  EXISTS (select  Resc_id  from  dbo.Res_Coach  where  Resc_id  Is  null )

 

注:不管where条件中得子查询和主查询有没有关系,遍历主查询中得每一条时,判断where条件,exists结果为真,where条件返回true,拿出该条记录,where条件返回false 不返回该记录。

 

SQLINEXISTS用法的区别

 

in 是把外表和内表作hash 连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询。

这两个函数是差不多的但是由于优化方案的不同:

NOT  EXISTS要比NOT  IN not in not exists如果查询语句使用了not in 那么内外表都进行全表扫描,没有用到索引;而not extsts 的子查询依然能用到表上的索引。所以无论那个表大,用not exists都比not in要快。因为NOT  EXISTS可以使用结合算法而NOT  IN 就不行了。

IN 要比EXISTS因为这时候IN可能更多的使用结合算法。如果查询的两个表大小相当,那么用inexists差别不大。如果两个表中一个较小,一个是大表,则子查询表大的用exists,子查询表小的用in

exits 相当于存在量词:表示集合存在,也就是集合不为空(只作用一个集合)。例如 exist P 表示P不空时为真;not exist P表示p为空时为真。in表示一个标量和一元关系的关系。例如:s in P表示当sP中的某个值相等时为真; s not in P 表示sP中的每一个值都不相等时为真

例:

select getdate()
select * from tab_Resource where  Res_TypeTree_Id in  (select * from Split('1,3,361,16619,16620,16621,16622',',')) 
select getdate()

 

select getdate()
select * from tab_Resource 
where  exists((select col from Split('1,3,361,16619,16620,16621,16622',',') where Res_TypeTree_Id=col))
select getdate()

SQL in  =的区别

 

select name from student where name in ('zhang','wang','li','zhao');

select name from student where name='zhang' or name='li' or name='wang' or name='zhao'

的查询结果是相同的。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值