SQL中exist与in的区别

原创 2007年10月06日 01:38:00

in 和 exists也是很好区别的.
in 是一个集合运算符:a in {a,c,d,s,d....} 这个运算中,前面是一个元素,后面是一个集合。集合中的元素类型是和前面的元素一样的.。
而exists是一个存在判断,如果后面的查询中有结果,则exists为真,否则为假.
in 运算用在语句中,它后面带的select 一定是选一个字段,而不是select *。比如说你要判断某班是否存在一个名为"小明"的学生,你可以用in 运算:
"小明" in (select sname from student)这样(select sname from student) 返回的是一个全班姓名的集合,in用于判断"小明"是否为此集合中的一个数据;
同时,你也可以用exists语句:exists (select * from student where sname="小明")  

这两个涵数是差不多的, 但是由于优化方案的不同, 通常NOT EXISTS要比NOT IN 要快, 因为NOT EXISTS可以使用结合算法而NOT IN 就不行了,而EXISTS则不如IN快, 因为这时候IN可能更多的使用结合算法.

select * from 表A where exists(select * from 表B where 表B.id=表A.id)
这句相当于
select * from 表A where id in (select id from 表B)

对于表A的每一条数据,都执行select * from 表B where 表B.id=表A.id的存在性判断,如果表B中存在表A当前行相同的id,则exists为真,该行显示,否则不显示
exits适合内小外大的查询,in适合内大外小的查询 

IN 确定给定的值是否与子查询或列表中的值相匹配。
EXISTS 指定一个子查询,检测行的存在。
比较使用 EXISTS 和 IN 的查询
这个例子比较了两个语义类似的查询。第一个查询使用 EXISTS 而第二个查询使用 IN。注意两个查询返回相同的信息。

USE pubs
GO
SELECT DISTINCT pub_name
FROM publishers
WHERE EXISTS
(SELECT *
FROM titles
WHERE pub_id = publishers.pub_id
AND type = 'business')
GO

-- Or, using the IN clause:

USE pubs
GO
SELECT distinct pub_name
FROM publishers
WHERE pub_id IN
(SELECT pub_id
FROM titles
WHERE type = 'business')
GO

下面是任一查询的结果集:

pub_name
----------------------------------------
Algodata Infosystems
New Moon Books

(2 row(s) affected)

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

版权声明:本文为博主原创文章,未经博主允许不得转载。

SQL中IN和EXISTS用法的区别,sql中exists,not exists的用法

NOT IN SELECT DISTINCT MD001 FROM BOMMD WHERE MD001 NOT IN (SELECT MC001 FROM BOMMC) NOT EXISTS,ex...
  • wozengcong
  • wozengcong
  • 2015年05月18日 09:28
  • 5862

关于Oracle中in和exists的区别

1、关于在 Oracle8i  时代中in和exists的区别   这里有条SQL语句:select * from A where id in(select id from B)  以上查询使...
  • okh258
  • okh258
  • 2015年12月17日 16:55
  • 2749

sql语句中exists和in用法的区分

初学java两个多月,这两天在整理老师的笔记对数据库中的exists和in的用法分不清楚,从网上搜了些资料,作了点总结。 一、问题起因 起初是由两条语句执行结果不同,语句如下: --分析以下结果...
  • U___U
  • U___U
  • 2015年03月27日 15:25
  • 4226

oracle sql 多表 嵌套子查询 连接查询, join where exist in 的区别

sql中exits和in的区别 转:http://hi.baidu.com/delphi_relive/blog/item/d7c0034a49c4932208f7ef21.html in 和...
  • wguoyong
  • wguoyong
  • 2011年11月12日 17:02
  • 13320

sql中的in 和 exist 区别

select * from A where id in(select id from B) 以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表...
  • USERNAME_FB
  • USERNAME_FB
  • 2012年07月27日 15:20
  • 314

SQL中in与exist的区别

select * from A where id in(select id from B)以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B...
  • u010846873
  • u010846873
  • 2016年08月18日 20:05
  • 242

关于in 和 exist 的区别-------------近期优化sql 语句的时候再次碰到

近期优化sql 语句的时候再次碰到 看到数据库查询中一些用法有些不合理,并且执行的效率很低,碰到了in 与exists 的相关用法 本来是想拿自己数据库里面的例子来展示的,有些不允许,所有就找了...
  • cainiaoxiaozhou
  • cainiaoxiaozhou
  • 2015年09月08日 10:26
  • 387

sql中exist与in的区别

in 和 exists也是很好区别的. in 是一个集合运算符.a in {a,c,d,s,d....}这个运算中,前面是一个元素,后面是一个集合,集合中的元素类型是和前面的元素一样的. 而exist...
  • javadxz
  • javadxz
  • 2011年05月20日 11:56
  • 352

IN 和 EXIST的区别

  • 2012年05月22日 06:59
  • 38KB
  • 下载

SQL语句,多表查询,连接查询,嵌套查询,集合操作,有IN谓词,有比较运算符,有ANY\EXIST谓词的查询

---查询每个学生及选修课程的情况 SELECT S.*,SC.*  FROM S,SC WHERE S.SNO=SC.SNO; ---查询每个学生及选修课程,这个是用自然连接弄的,结果同上 ...
  • li603060971
  • li603060971
  • 2015年12月27日 11:10
  • 1059
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQL中exist与in的区别
举报原因:
原因补充:

(最多只允许输入30个字)