




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
目标通过本章学习,您将可以:描述子查询可以解决的问题定义子查询。列句子查询的类型。书写单行子查询和多行字查询。使用子查询解决问题谁的工资比Abel
高?谁的工资比Abel
高?MainQuery:?Abel的工资是多少?Subquery?子查询语法子查询(内查询)在主查询之前一次执行完成。子查询的结果被主查询使用(外查询)。SELECTFROMWHEREselect_listtableexpr
operator(SELECTFROMselect_listtable);SELECT
last_nameFROMWHEREemployeessalary
>(SELECT
salaryFROMWHEREemployeeslast_name
=
'Abel');子查询11000注意事项子查询要包含在括号内。将子查询放在比较条件的右侧。除非进行Top-N
分析,否则不要在子查询中使用ORDERBY
子句。单行操作符对应单行子查询,多行操作符对应多行子查询。子查询类型MainquerySubqueryreturnsST_CLERK多行子查询ST_CLERKSA_MANMainquerySubqueryreturns单行子查询单行子查询只返回一行。使用单行比较操作符。Operator
Meaning= Equal
to> Greater
than>= Greater
than
or
equal
to< Lessthan<= Less
thanor
equal
to<> Not
equal
toSELECT
last_name,
job_id,
salaryFROM
employeesWHERE job_id
=(SELECT
job_idFROM
employeesWHERE employee_id
=
141)ANDsalary
>(SELECT
salaryFROM
employeesWHERE employee
id
=
143);执行单行子查询ST_CLERK2600SELECT
last_name,
job_id,
salaryFROMWHEREemployeessalary
=(SELECT
MIN(salary)FROM
employees);在子查询中使用组函数2500子查询中的HAVING
子句首先执行子查询。向主查询中的HAVING
子句返回结果。SELECTFROMdepartment_id,
MIN(salary)employeesGROUP
BY
department_idHAVING MIN(salary)
>FROM
employeesWHERE department_id
=
50);2500(SELECT
MIN(salary)salarySELECT
employee_id,
last_nameFROM
employeesWHERE
=(SELECTFROMMIN(salary)employees使用子查询GROUP
BY
department
id);ERROR
at
line
4:ORA-01427:
single-row
subquery
returns
more
thanone
row子查询中的空值问题no
rows
selectedSELECT
last_name,
job_idFROM
employeesWHERE job_id
=(SELECT
job_idFROMWHEREemployeeslast_name
=
'Haas');多行子查询ANYALL返回多行。使用多行比较操作符。Operator
MeaningIN
Equal
to
any
member
in
the
listCompare
value
to
each
value
returnedbythe
subquery
只要满足其中至少一个条件Compare
value
to
every
value
returnedbythe
subquery
必须满足其中所有条件在多行子查询中使用ANY
操作符9000,
6000,
4200SELECT
employee_id,
last_name,
job_id,
salaryFROMWHEREemployeessalary
<ANY(SELECT
salaryFROM
employeesWHERE job_id
=
'IT_PROG')ANDjob_id
<>
'IT_PROG';…SELECT
employee_id,
last_name,
job_id,
salaryFROM
employeesWHERE salary
<ALL(SELECT
salaryFROM
employeesWHERE job_id
=
'IT_PROG')ANDjob_id
<>
'IT_PROG';在多行子查询中使用ALL
操作符9000,
6000,
4200子查询中的空值问题SELECT
emp.last_nameFROMWHEREemployees
empemp.employee_id
NOT
IN(SELECT
mgr.manager_idFROM employees
mgr);no
rows
selected总结通过本章学习,您已经学会:在什么时候遇到什么问题应该使用子查询。在查询是基于未知的值时应使用子查询。SELECTFROMWHEREselect_listtableexpr
operator(SELECT
select_listFROM
table);Practice6
OverviewThis
practicecovers
thefollowing
topics:Creating
subqueries
to
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 流动酒席出售合同范本
- 乡下洋房售卖合同范本
- 简单租场地合同范本
- 拆活动板房合同范本
- 共同买店面合同范本
- 玉米批发合同范本
- 畜禽疫苗销售合同范本
- 建筑木工包工合同范本
- 小切口历史-中国古代历代货币考点汇编
- 老人赠送地基合同范本
- 生产车间5S稽核评分表
- cmk 设备能力分析计数表格
- 道路运输领域重大事故风险链鱼骨图
- 河南2023年河南省农村信用社(农商银行)员工招聘考试参考题库含答案详解
- 法兰西喜剧院
- 电力市场交易体系规则培训PPT
- 2022年新改版教科版五年级下册科学全册实验记录单(实验必备)
- 医学检验心壁的组织结构
- 江苏省南京市联合体2022-2023八年级初二下学期道德与法治期中试卷+答案
- 《小池》说课稿 小学一年级语文教案PPT模板下载
- 112尿道肉阜临床路径
评论
0/150
提交评论