Oracle with子句

2014-11-24 18:33:17 · 作者: · 浏览: 1

以例子学习with:


注释:


① 子查询可重用相同或者前一个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子查询与下面的实际查询之间没有逗号