以例子学习with:
- with
- --查询部门和部门的总薪水
- dept_costs as (
- select d.department_name,sum(e.salary) dept_total
- from departments d,employees e
- where d.department_id=e.department_id
- group by d.department_name
- ),
- --利用上一个with查询的结果,计算部门的平均总薪水
- avg_costs as (
- select avg(dept_total) dept_avg
- from dept_costs
- )
- --从两个with查询中比较并且输出查询结果
- select *
- from dept_costs
- where dept_total > (select dept_avg from avg_costs)
- order by department_name
注释:① 子查询可重用相同或者前一个with查询块,通过select调用(with子句也只能被select调用)② with子句的查询输出存储到用户临时表空间,一次查询,到处使用③ 同级select前有多个查询定义,第一个用with,后面的不用with,并且用逗号分割④ 最后一个with查询块与下面的select调用之间不能用逗号分割,只通过右括号分离,with子句的查询必须括号括起⑤ 如果定义了with子句,而在查询中不使用,则会报ora-32035错误,只要后面有引用的即可,不一定在select调用,在后with查询块引用也是可以的⑥ 前面的with子句定义的查询在后面的with子句中可以使用,但是一个with子句内部不能嵌套with子句⑦ with查询的结果列有别名,引用时候必须使用别名或者*再来看with的语法㈠ as和select中的括号不能省略㈡ 同级别select调用,with只能定义一次,多个用逗号分隔,但最后一个with子查询与下面的实际查询之间没有逗号
Oracle insert的扩展MySQL 5.5 DBA工具 多进程dump 多进程load 多进程备份还原 Python 脚本相关资讯 Oracle基础知识
- 查看Oracle 32位还是64位(x86 or (10/05/2014 19:10:00)
- Oracle中表的建立与修改-五种约束 (02/07/2013 09:49:18)
- Oracle select 语句字段连接 (12/17/2012 14:51:53)
| - Oracle online redo log 基础知识 (02/09/2013 09:43:04)
- 如何查看Oracle数据库的session阻 (01/01/2013 09:11:15)
- Oracle Redo Log 及Logmnr配置使用 (12/14/2012 19:36:51)
|
本文评论 查看全部评论 (0)