度量快速开发平台-专业、快速的软件定制快开平台
标题: oracle数据库中 with as简介 [打印本页]
作者: caixuqad 时间: 2020-4-24 17:46
作者: caixuqad 时间: 2020-4-27 18:10
作者: caixuqad 时间: 2020-4-28 17:46
作者: caixuqad 时间: 2020-4-28 17:47
作者: 张兴康 时间: 2020-4-29 11:47
作者: caixuqad 时间: 2020-5-1 17:29
作者: caixuqad 时间: 2020-5-4 17:49
作者: 张兴康 时间: 2020-5-5 17:18
作者: caixuqad 时间: 2020-5-5 17:31
作者: 张兴康 时间: 2020-5-6 14:00
作者: caixuqad 时间: 2020-5-6 17:45
作者: 张兴康 时间: 2020-5-7 15:18
作者: caixuqad 时间: 2020-5-7 16:58
作者: 张兴康 时间: 2020-5-30 17:04
标题: oracle数据库中 with as简介
with as语法:
–针对一个别名
with tmp as (select * from tb_name)
–针对多个别名
with
tmp as (select * from tb_name),
tmp2 as (select * from tb_name2),
tmp3 as (select * from tb_name3),
…
With查询语句以“WITH”关键字开头,可认为在真正进行查询之前预先构造了一个临时表TT,之后便可多次使用它做进一步的分析和处理
优点:增加了SQL的易读性,如果构造了多个子查询,结构会更清晰;更重要的是:“一次分析,多次使用”,这也是为什么会提供性能的地方,达到了“少读”的目标
例如:现在要从1-20中得到11-14。一般的sql如下:
使用With as 的SQL为:
第一种使用子查询的方法表被扫描了两次,而使用WITH Clause方法,表仅被扫描一次。这样可以大大的提高数据分析和查询的效率
作者: 陈晓龙 时间: 2020-6-4 14:02
这个我很少用,先收藏起!
作者: 陈晓龙 时间: 2020-6-4 14:02
这个我很少用,先收藏起!
作者: 王爱东 时间: 2020-6-4 16:02
可以,这样看来运行效率是很高的。
作者: 张兴康 时间: 2020-6-4 17:08
以前都不太清楚,最近看到很多人代码都这样写,才了解的
欢迎光临 度量快速开发平台-专业、快速的软件定制快开平台 (http://plat.delit.cn/) |
Powered by Discuz! X3.2 |