度量快速开发平台-专业、快速的软件定制快开平台

标题: 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 发表于 2017-12-5 17:31


作者: 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://bbs.delit.cn/) Powered by Discuz! X3.2