文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>sql查询关建字之-exists, in. all, any, some

sql查询关建字之-exists, in. all, any, some

时间:2010-12-28  来源:itcfj

SQL中exists和in的区别

两张表——用户表TDefUser(userid,address,phone)和消费表TAccConsume(userid,time,amount),需要查消费超过5000的用户记录。
用exists:
select * from TDefUser
where exists (select 1 from TAccConsume whereTDefUser.userid=TAccConsume.userid and TAccConsume.amount>5000)
用in:
select * from TDefUser
where userid in (select userid from TAccConsume whereTAccConsume.amount>5000)

通常情况下采用exists要比in效率高。

exists()后面的子查询被称做相关子查询 他是不返回列表的值的.只是返回一个ture或false的结果(这也是为什么子查询里是"select 1"的原因,换成"select6"完全一样,当然也可以select字段,但是明显效率低些)
其运行方式是先运行主查询一次 再去子查询里查询与其对应的结果 如果是ture则输出,反之则不输出.再根据主查询中的每一行去子查询里去查询.

in()后面的子查询 是返回结果集的,换句话说执行次序和exists()不一样.子查询先产生结果集,然后主查询再去结果集里去找符合要求的字段列表去.符合要求的输出,反之则不输出.

比如用户表TDefUser(userid,address,phone),消费表TAccConsume(userid,time,amount)数据如下:

消费表聚集索引是userid,time
数据(注意因为有聚集索引,实际存储也是按以下次序的)
1    2006-1-1   200
1    2006-1-2   300
1    2006-1-2   500
1    2006-1-3   2000
1    2006-1-3   2000
1    2006-1-4   400
1    2006-1-5   500
2    2006-1-1   200
2    2006-1-2   300
2    2006-1-2   500
2    2006-1-3   2000
2    2006-1-3   6000
2    2006-1-4   400
2    2006-1-5   8000
3    2006-1-1   7000
3    2006-1-2   30000
3    2006-1-2   50000
3    2006-1-3   20000

语句:
select * from TDefUser
where exists (select 1 from TAccConsume whereTDefUser.userid=TAccConsume.userid and TAccConsume.amount>5000)

对于userid=1,需要找所有记录,才返回false,与第二个语句的效率差不多
对于userid=2,找到2006-1-3的记录,就返回true,比第而个语句的效率高
对于userid=3,第一条记录就返回true,比第二个语句的效率高

语句
select * from TDefUser
where userid in (select userid from TAccConsume whereTAccConsume.amount>5000)

返回空记录集
2
2
3
3
3
3

再判断

语句
select * from TDefUser
where userid in (select userid from TAccConsume where userid=TDefUser.userid andamount>5000)

对于userid=1,需要找所有记录,返回空记录集,比较判断
对于userid=2,需要找所有记录,返回记录集
2
2
,比较判断
对于userid=3需要找所有记录,返回记录集
3
3
3
3
,比较判断

表中如果没有聚集索引,对exists每个userid查找的条数都不同,但都是<=第三个语句需要扫描的条数,极端的(比如>5000的都是在最后)与第三个语句效率相似,一般的比第二个语句快,所以说,“一般”exists比in效率高


all, any, some的区别
1.All

对所有数据都满足条件,整个条件才成立
select *
from A
where 5>All(select id from A) --所有的值都要大于5


2.Any

只要有任一条数据满足条件,整个条件成立
select *
from A
where 3>any(select id from A) --当结果中只要有一个值小于3条件就可成立
go


3.Some和Any一样表示的限制相同

 

相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载