`
favor
  • 浏览: 144024 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

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

阅读更多
SQL中exists和in的区别

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

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

exists()后面的子查询被称做相关子查询 他是不返回列表的值的.只是返回一个ture或false的结果(这也是为什么子查询里是"select 1"的原因,换成"select 6"完全一样,当然也可以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 where TDefUser.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 where TAccConsume.amount>5000)

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

再判断

语句
select * from TDefUser
where userid in (select userid from TAccConsume where userid=TDefUser.userid and amount>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一样表示的限制相同
分享到:
评论

相关推荐

    s-sql 自学通

    - **EXISTS、ANY、ALL的使用:** EXISTS用于检查子查询是否存在结果;ANY和ALL用于比较子查询的结果。 #### 十一、操作数据 - **数据操作语句:** - `INSERT INTO table_name (column1, column2, ...) VALUES ...

    SQL数据的查询和更新实验报告报告.pdf

    - **SOME, ANY, ALL**:比较子查询结果中的任何值或所有值 - **EXISTS**:检查子查询是否存在匹配项 #### 1.4 集合运算 - **UNION**:合并两个或更多查询的结果,去除重复行 - **AND, OR**:用于组合查询,实现...

    T-SQL高级查询

    # some、any、all子句查询示例 查询班级的学生年龄大于班级的学生的年龄的信息 select * from student where cid = 5 and age &gt; all ( select age from student where cid = 3 ); select * from student where ...

    MS-SQL子查询语句集[文].pdf

    MS-SQL中的子查询主要分为几种类型,包括EXISTS、IN、NOT IN以及ANY/SOME。以下是对这些子查询类型的详细解释: 1. EXISTS: EXISTS子查询用于检查子查询是否返回至少一行数据。它的语法结构是`EXISTS (subquery)`...

    在ADO(sql)中使用SELECT的语法之六-子查询的使用方法

    ### 在ADO(SQL)中使用SELECT的语法之六——子查询的使用方法 #### 一、子查询概述 在SQL查询语言中,子查询是一个非常重要的概念。子查询是指在一个SQL命令内部嵌套另一个完整的SQL查询命令。通过使用子查询,我们...

    SQL多层查询[借鉴].pdf

    在SQL查询中,多层查询,也称作嵌套查询,是一种高级的查询技术,它允许在一个查询语句中嵌入另一个查询语句,以实现更复杂的数据筛选和比较。这种技术极大地增强了SQL的能力,使其能够处理更复杂的逻辑和数据关联。...

    数据库实验四:SQL数据查询.doc

    - **嵌套查询**:使用IN、NOT IN、ANY、ALL和EXISTS等关键字进行嵌套查询。 - **汇总和分组查询**:利用COUNT、SUM等函数进行统计、分组查询。 #### 一般简单查询 - **不带条件的查询指定字段**:SELECT语句用于...

    SQL语句培训教材--实用

    - `ANY`, `SOME` 和 `ALL`:用于比较一个值与一组值的关系。 - `EXISTS` 和 `NOT EXISTS`:用于检查子查询的结果是否存在。 - `AND` 和 `OR`:逻辑运算符,用于组合多个条件。 - `UNION` 和 `UNION ALL`:用于合并两...

    微软内部资料-SQL性能优化5

    In SQL Server 2000, all clustered indexes are unique. If you build a clustered index without specifying the unique keyword, SQL Server forces uniqueness by adding a uniqueifier to the rows when ...

    SQL数据的查询和更新实验报告报告.docx

    + 第三类,SOME、ANY 或 ALL 谓词的子查询,查询最大值和最小值。 + 第四类,带有 EXISTS “”谓词的子查询,实现所有等情况。 四、集合运算 * 使用保留字 UNION 进行集合或运算。 * 采用逻辑运算符 AND 或 OR ...

    1704091029-蔡腾飞-数据库实验四.docx

    - **使用ANY或SOME的简单嵌套查询**:例如,查询所有教师编号小于某课程的责任教师编号的教师信息:`SELECT * FROM 教师 WHERE 教师编号 &lt; ANY (SELECT 责任教师编号 FROM 课程);`。 - **使用ALL的简单嵌套查询**:...

    课程名称:数据库系统概论仲恺农业技术学院(“查询”文档)共66张.pptx

    三、带有ANY(SOME)或ALL谓词的子查询 ANY和ALL谓词用于比较主查询中的值与子查询结果集中的值。ANY表示只要有一个匹配即可,而ALL则要求所有值都匹配。 1. ANY(SOME): - `Sage &gt; ANY (SELECT Sage FROM ...

    SQL-SELECT(任明汉).doc

    使用 ANY/SOME 和 ALL 量词来比较某个值与子查询结果集中的所有值。 - **EXISTS**:用于检查子查询是否至少返回一行数据。 #### 10. 连接类型 - **自身连接**:指同一个表与自身之间的连接,常用于分析数据间的...

    实验5 数据查询.docx

    - **ANY 或 SOME**:查询满足子查询中任意条件的数据。 - **ALL**:查询满足子查询中所有条件的数据。 - **嵌套查询与连接查询的效率对比**:分析在特定场景下哪种更优。 - **内外层相关嵌套查询**:子查询结果...

    微软内部资料-SQL性能优化2

    In this module we will discuss Microsoft® SQL Server™ interaction with the operating system and methodology of troubleshooting server-based problems. At the end of this module, you will be able to:...

    DM7_SQL语言使用手册.pdf

    - **4.3.4 定量比较**: 使用IN、ANY/SOME、ALL等进行比较。 - **4.3.5 带EXISTS谓词的子查询**: 检查是否存在满足条件的行。 - **4.3.6 多列表子查询**: 处理多个结果集。 **4.4 WITH子句** - **4.4.1 WITH ...

Global site tag (gtag.js) - Google Analytics