您的位置:首页 > 数据库

sql中exist与in的区别

2011-08-17 10:15 176 查看
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中的每一个值都不相等时 为真
来源:http://hi.baidu.com/delphi_relive/blog/item/d7c0034a49c4932208f7ef21.html
———————————————————————————————————————
请解释 select * from tt t where not exists(select 1 from tt where 姓名=t.姓名 and 薪资>t.薪资)

Q:
select * from tt t where not exists(select 1 from tt where 姓名=t.姓名 and 薪资>t.薪资 )

类似的句子用途很广泛,可我想知道,这句话的逻辑或思路是怎样的啊,恕我愚笨,不太明白。

或者解释一下这句话,也可以。
A:
select * from tt t where not exists(select 1 from tt where 姓名=t.姓名 and 薪资>t.薪资 )

对于表tt的记录进行扫描,

对于其中任一条记录,查询相同表中相同姓名的记录,查找其中是否存在薪资>当前记录的薪资的记录,如存在,扫描到的记录即不符合条件,

如不存在,即扫描到的记录符合where的条件,将作为查询结果.

考虑最简单的情况

姓名,薪资

chen,1000 --此记录与全部chen记录1000-4000比较,2000以上>1000存在查询结果,此记录不符合where 条件

chen,2000 --此记录与全部chen记录1000-4000比较,3000以上>2000存在查询结果,此记录不符合where 条件

chen,3000 --此记录与全部chen记录1000-4000比较,4000>3000存在查询结果,此记录不符合where 条件

chen,4000 --此记录与全部chen记录1000-4000比较,没有>4000的记录,此记录符合where 条件

最后符合条件的记录为

chen,4000

条件就是查询相同姓名 没有比查询的记录的薪资高的记录

实际结果就是薪资的最大值.
来源:http://topic.csdn.net/u/20081008/16/15cc40f2-cb0f-46e4-b951-3193314c4279.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: