Oracle WITH AS 用法

前言

 可以把WITH AS 的用法看成赋值的用法,以减少SQL语句的冗余。
 当我们在SQL语句中频繁的利用某一个Select查询语句作为数据源时,我们可以用WITH AS 的用法进行简写
 增加了SQL的易读性,如果构造了多个子查询,结构会更清晰;更重要的是:“一次分析,多次使用”。

语法

with tempName1 as (select ....),tempName2 as (select ....)
select ...from  tempName 

例子

例子:

//普通使用方法
Select * from (
    select name ,age from stu
    union 
    select name,age from tech
    union
    …
)

//wtih as 
with schoolPeople as (
    select name ,age from stu
    union 
    select name,age from tech
    union
    …
)
select * from schoolPeople

注意事项

  • ① 子查询可重用相同或者前一个with查询块,通过select调用(with子句也只能被select调用)
  • ② with子句的查询输出存储到用户临时表空间,一次查询,到处使用
  • ③ 同级select前有多个查询定义,第一个用with,后面的不用with,并且用逗号分割
  • ④ 最后一个with查询块与下面的select调用之间不能用逗号分割,只通过右括号分离,with子句的查询必须括号括起
  • ⑤如果定义了with子句,而在查询中不使用,则会报ora-32035错误,只要后面有引用的即可,不一定在select调用,在后with查询块引用也是可以的
  • ⑥ 前面的with子句定义的查询在后面的with子句中可以使用,但是一个with子句内部不能嵌套with子句
  • ⑦ with查询的结果列有别名,引用时候必须使用别名或者*
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值