转:http://hi.baidu.com/delphi_relive/blog/item/d7c0034a49c4932208f7ef21.html

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中的每一个值都不相等时 为真

二 、连接查询

SELECT

Persons.LastName, Persons.FirstName, Orders.OrderNoFROM Persons

INNER JOIN

Orders ON Persons.Id_P =

Orders.Id_P ORDER BY Persons.LastName

不同的 SQL

JOIN 返回的结果集不一样

除了我们在上面的例子中使用的 INNER

JOIN(内连接),我们还可以使用其他几种连接。

下面列出了您可以使用的 JOIN 类型,以及它们之间的差异。

JOIN: 如果表中有至少一个匹配,则返回行

LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行

RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行

FULL JOIN: 只要其中一个表中存在匹配,就返回行

注释:INNER JOIN 与 JOIN 是相同的。

简而言之 ,就是你希望看到的结果集是怎样的,如两个表 person 和

order 连接 :

如果你只想看到person 中 和order 有联系的记录 即 满足 order.id_p =

person.id的记录其他不匹配的全不显示 就用 inner join

left join 就是在返回inner join 的结果集的基础上返回左表 person 表中

其余的记录(这些显示的记录行所有与order表相关的栏为空,因为它们不满足匹配关系)

同理 ,right

join 和 full

join

3)嵌套子查询

select t.deptno,count(*) from emp t,(select avg(e.sal) avgsal from emp e) a

where t.sal>a.avgsal

group by t.deptno

where 运算符 (=,,>=,<=,<>) where 运算符 (in,not

in,exists,not exists, all,any)

相关子查询是指引用了父查询中某些表或某些列的子查询(但父查询不能引用子查询中的表或列)父查询可以是select,update,delete

子句。

4)sql 中的聚合

函数的嵌套 使用

聚集函数

和大多数其它关系数据库产品一样,PostgreSQL

支持聚集函数。一个聚集函数从多个输入行中计算出一个结果。比如,我们有在一个行集合上计算 count(数目), sum(总和),

avg(均值), max(最大值), min(最小值)的函数。

比如,我们可以用下面的语句找出所有低温中的最高温度:

SELECT max(temp_lo) FROM weather; max

-----

46

(1 row)如果我们想知道该读数发生在哪个城市,可能会用:

SELECT city FROM weather WHERE temp_lo =

max(temp_lo); -- 错!不过这个方法不能运转,因为聚集函数 max 不能用于 WHERE 子句中。存在这个限制是因为 WHERE

子句决定哪些行可以进入聚集阶段;因此它必需在聚集函数之前计算。不过,我们可以用其它方法实现这个目的;这里我们使用子查询:

SELECT city FROM weather

WHERE

temp_lo = (SELECT max(temp_lo) FROM

weather); city

---------------

San Francisco

(1 row)这样做是可以的,因为子查询是一次独立的计算,它独立于外层查询计算自己的聚集。

聚集同样也常用于 GROUP BY 子句。比如,我们可以获取每个城市低温的最高值:

SELECT city, max(temp_lo)

FROM

weather

GROUP BY

city; city | max

---------------+-----

Hayward | 37

San Francisco | 46

(2 rows)这样每个城市一个输出。每个聚集结果都是在匹配该城市的行上面计算的。我们可以用 HAVING 过滤这些分组:group by 可以没有 having 过滤 having必须跟在group by的后面 SELECT city, max(temp_lo)

FROM

weather

GROUP BY

city

HAVING

max(temp_lo) < 40; city | max

---------+-----

Hayward | 37

(1 row)这样就只给出那些 temp_lo 值曾经有低于 40

度的城市。最后,如果我们只关心那些名字以"S"开头的城市,我们可以用:

SELECT city, max(temp_lo)

FROM

weather

WHERE city

LIKE 'S%'

GROUP BY

city

HAVING

max(temp_lo) < 40;语句中的 LIKE 执行模式匹配,在节9.7里有解释。

理解聚集和 SQL 的 WHERE 和 HAVING 子句之间的关系非常重要。WHERE 和 HAVING 的基本区别如下:WHERE

在分组和聚集计算之前选取输入行(它控制哪些行进入聚集计算),而 HAVING 在分组和聚集之后选取输出行。因此,WHERE

子句不能包含聚集函数;因为试图用聚集函数判断那些行将要输入给聚集运算是没有意义的。相反,HAVING

子句总是包含聚集函数。当然,你可以写不使用聚集的 HAVING 子句,但这样做没什么好处,因为同样的条件可以更有效地用于 WHERE

阶段。

在前面的例子里,我们可以在 WHERE 里应用城市名称限制,因为它不需要聚集。这样比在 HAVING

里增加限制更加高效,因为我们避免了为那些未通过 WHERE 检查的行进行分组和聚集计算。

oracle多表嵌套查询使用,oracle sql 多表 嵌套子查询 连接查询, join where exist i...相关推荐

  1. mysql 嵌套查询性能_mysql SQL优化之嵌套查询-遁地龙卷风

    (-1) 写在前面 这篇随笔的数据使用的是http://blog.csdn.net/friendan/article/details/8072668#comments里的,里面有一些常见的select ...

  2. mysql左连接sql语句详解_SQL各种连接查询详解(左连接、右连接..)

    一.交叉连接(cross join) 交叉连接(cross join):有两种,显式的和隐式的,不带on子句,返回的是两表的乘积,也叫笛卡尔积. 例如:下面的语句1和语句2的结果是相同的. 语句1:隐 ...

  3. SQL service基础(四)连接查询、自身连接查询、外连接查询和复合条件连接查询

    实验目标: 1.掌握涉及一个以上数据表的查询方法. 2.掌握等值连接 3.掌握自然连接 4.掌握非等值连接 5.掌握自身连接.外连接和复合条件连接 本次实验sql脚本: INSERT [dbo].[T ...

  4. sql中什么时候用内连接查询,什么时候用外连接查询

    需要查找两张表同时存在的数据,使用内连接 需要查找两张表中一张表存在,另一张表不存在的时候使用左外链接 或 右外链接 内连接的查询结果都是满足连接条件的元组.但有时我们也希望输出那些不满足连接条件的元 ...

  5. SQL server 两台服务器间连接查询

    --两台服务器间连接查询: --建立连接: sp_addlinkedserver hs sp_addlinkedserver hs1 EXEC sp_addlinkedsrvlogin 'hs', ' ...

  6. 使用内连接查询选修了Java程序基础_使用内连接 查询选修了“java程序基础”课程的学生学号、姓名、课程号、课程名和期末成绩_学小易找答案...

    [简答题]BOD5/COD比值说明什么? [单选题]在制图中有一实物的某个尺寸为10,绘图时采用的比例为1:2.标注是应标注( ) [判断题]在表格布局中,有多少列就看最多的一个行中添加多少个控件,直 ...

  7. mysql左连接表要取最新的一条数据_MySQL的左连接查询,只取出最大的一条数据...

    今天有个需求,是通过两张表进行查询.一对多的关系.通过一个主键,取出其中的一条. 开始以为还好,直接用用了left join on进行查询.却发现了问题所在. 其他的好弄. 开始的写法借鉴这篇博客: ...

  8. 用sql改oracle表结构,SQL server 表结构转Oracle SQL脚本

    SQL server 表结构转Oracle SQL脚本 /****** Object: StoredProcedure [dbo].[getOracle] Script Date: 2019/7/25 ...

  9. SQL连接查询和嵌套查询详解

    连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询.连接查询是数据库中最最要的查询, 包括: 1.等值连接查询 2.自然连接查询 3.非等值连接查询 4.自身连接查询 5.外连接查询 6 ...

  10. php sql查询两个表语句,sql多表查询语句与方法

    sql多表查询有很多种方法,如有自然连接 INNER JOIN,外边查询LEFT JOIN,交叉查询JOIN,交叉连接JOIN等join on left on 等多的是哦. sql多表查询语句与方法 ...

最新文章

  1. 用jsp实现右导航窗格_不想升级操作系统,可以用这三种方法阻止Windows10更新
  2. javascript体系-DOM原理
  3. 5 步助你成为一名优秀的 Docker 代码贡献者
  4. Mac终端显示 bogon的问题
  5. 使用命名空间解决名字冲突
  6. ITK:观察事件 Observe An Event
  7. 167. Two Sum II - Input array is sorted (C, C++, Python)
  8. javascript Math object
  9. 自动驾驶公司 | 纵目科技完成D轮1.9亿美元融资
  10. Linux使用docker安装RabbitMQ一站式教程【图文教程】
  11. windows批量ping脚本
  12. 什么是AOP(通俗易懂)
  13. 苹果手机微信声音小怎么调大声_今天才知道,微信语音隐藏的3个功能,太实用了,看完涨知识了...
  14. 计算机开机速度慢是什么原因,电脑开机慢是什么原因?怎么处理?
  15. oracle 列转行字符串,oracle 字符串列转行
  16. PHP isset()和empty()区别
  17. 基于51单片机HX711的电子秤称重计价proteus仿真程序设计
  18. 一点关于优化手写笔迹
  19. [论文笔记] Fusion++: VolumetricObject-LevelSLAM
  20. linux fcitx改mac输入法,Linux安装fcitx输入法

热门文章

  1. 基于 OPC 规范的客户应用程序实现
  2. Halcon PDF文档(hdevelop_users_guide)学习总结之一
  3. 澳大利亚超市巨头考虑设专门网站 方便代购买奶粉
  4. Google+ 团队的 Android UI 测试
  5. 7款优秀的开源数据挖掘工具
  6. 欲走考研,难辞青衫,小园香径独徘徊。
  7. 前后落差大用什么词语_【刺激】全国最长滑索!“白云飞索”全长1500米,落差200多米!...
  8. 天融信防火墙web配置_天融信协议转换交付系统震撼发布——IPv4/IPv6融合改造利器...
  9. mybatis存在就不插入_mybatis只能进行查找,不能进行删除,插入,更新解决方案...
  10. 埃斯顿服务器上电无显示,埃斯顿伺服常见现象报警及排除