Oracle公司内部数据库培训资料-Les18_高级子查询(PPT 31页)_第1页
Oracle公司内部数据库培训资料-Les18_高级子查询(PPT 31页)_第2页
Oracle公司内部数据库培训资料-Les18_高级子查询(PPT 31页)_第3页
Oracle公司内部数据库培训资料-Les18_高级子查询(PPT 31页)_第4页
Oracle公司内部数据库培训资料-Les18_高级子查询(PPT 31页)_第5页
已阅读5页,还剩26页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、18Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载高级子查询高级子查询 18-2Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载目标目标通过本章学习,您将可以通过本章学习,您将可以:书写多列子查询书写多列子查询子查询对空值的处理子查询对空值的处理在在 FROM 子句中使用子查询子句中使用子查询在在SQL中使用单列子查询中使用单列子查询相关子查询相关子查询书写相关子查询

2、书写相关子查询使用子查询更新和删除数据使用子查询更新和删除数据使用使用 EXISTS 和和 NOT EXISTS 操作符操作符使用使用 WITH 子句子句18-3Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载子查询子查询子查询是嵌套在子查询是嵌套在 SQL 语句中的另一个语句中的另一个SELECT 语句语句SELECT . FROM .WHERE .(SELECT . FROM . WHERE .)子查询子查询18-4Copyright Oracle Corporation, 2

3、001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载子查询子查询子查询子查询 (内查询内查询) 在主查询执行之前执行在主查询执行之前执行主查询使用子查询的结果主查询使用子查询的结果 (外查询外查询)SELECT select_listFROMtableWHEREexpr operator (SELECT select_list FROM table);18-5Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载SELECT last_na

4、meFROM employeesWHERE salary (SELECT salary FROM employees WHERE employee_id = 149) ;子查询应用举例子查询应用举例1050018-6Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载多列子查询多列子查询Main queryWHERE (MANAGER_ID, DEPARTMENT_ID) INSubquery100 90102 60124 5018-7Copyright Oracle Corporat

5、ion, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载列比较列比较多列子查询中的比较分为两种多列子查询中的比较分为两种: 成对比较成对比较不成对比较不成对比较18-8Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载成对比较举例成对比较举例SELECT employee_id, manager_id, department_idFROMemployeesWHERE (manager_id, department_id) IN

6、(SELECT manager_id, department_id FROM employees WHERE employee_id IN (178,174)ANDemployee_id NOT IN (178,174);18-9Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载不成对比较举例不成对比较举例SELECT employee_id, manager_id, department_idFROM employeesWHERE manager_id IN (SELECT man

7、ager_id FROM employees WHERE employee_id IN (174,141)AND department_id IN (SELECT department_id FROM employees WHERE employee_id IN (174,141)ANDemployee_id NOT IN(174,141);18-10Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载SELECT a.last_name, a.salary, a.department

8、_id, b.salavgFROM employees a, (SELECT department_id, AVG(salary) salavg FROM employees GROUP BY department_id) bWHERE a.department_id = b.department_idAND a.salary b.salavg;在在 FROM 子句中使用子查询子句中使用子查询18-11Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载单列子查询表达式单列子查询表达式

9、单列子查询表达式是在一行中只返回一列的子查询单列子查询表达式是在一行中只返回一列的子查询Oracle8i 只在下列情况下可以使用只在下列情况下可以使用, 例如例如:SELECT 语句语句 (FROM 和和 WHERE 子句子句)INSERT 语句中的语句中的VALUES列表中列表中Oracle9i中单列子查询表达式可在下列情况下使用中单列子查询表达式可在下列情况下使用:DECODE 和和 CASESELECT 中除中除 GROUP BY 子句以外的所有子句中子句以外的所有子句中18-12Copyright Oracle Corporation, 2001. All rights reserve

10、d.来自来自 中国最大的资料库下载中国最大的资料库下载单列子查询应用举例单列子查询应用举例在在 CASE 表达式中使用单列子查询表达式中使用单列子查询SELECT employee_id, last_name, (CASE WHEN department_id = THEN Canada ELSE USA END) locationFROM employees; (SELECT department_id FROM departmentsWHERE location_id = 1800)在在 ORDER BY 子句中子句中使用单列子查询使用单列子查询SELECT employee_id, la

11、st_nameFROM employees eORDER BY 20(SELECT department_name FROM departments d WHERE e.department_id = d.department_id);18-13Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载相关子查询相关子查询 相关子查询按照一行接一行的顺序执行,主查询的每一相关子查询按照一行接一行的顺序执行,主查询的每一行都执行一次子查询行都执行一次子查询GET从主查询中获取候选列从主查询中获

12、取候选列EXECUTE子查询使用主查询的数据子查询使用主查询的数据USE如果满足内查询的条件则返回该行如果满足内查询的条件则返回该行18-14Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载相关子查询相关子查询 SELECT column1, column2, . FROM table1 WHERE column1 operator (SELECT colum1, column2 FROM table2 WHERE expr1 = .expr2);outerouter18-15Co

13、pyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载SELECT last_name, salary, department_idFROM employees outerWHERE salary 相关子查询举例相关子查询举例(SELECT AVG(salary) FROM employees WHERE department_id = outer.department_id) ;18-16Copyright Oracle Corporation, 2001. All rights rese

14、rved.来自来自 中国最大的资料库下载中国最大的资料库下载相关子查询举例相关子查询举例SELECT e.employee_id, last_name,e.job_idFROM employees e WHERE 2 (SELECT dept_avg FROM avg_cost)ORDER BY department_name;18-26Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载总结总结通过本章学习通过本章学习,您已经可以您已经可以: 使用多列子查询使用多列子查询多列子查询的

15、成对和非成对比较多列子查询的成对和非成对比较单列子查询单列子查询相关子查询相关子查询EXISTS 和和 NOT EXISTS操作符操作符相关更新和相关删除相关更新和相关删除WITH子句子句18-27Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载Hidden Slide18-28Copyright Oracle Corporation, 2001. All rights reserved.来自来自 中国最大的资料库下载中国最大的资料库下载Hidden Slide18-29Copyright Oracle Corporation, 2001. All rights res

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论