oracle with as 语句

来源:互联网 发布:德国做律师 知乎 编辑:程序博客网 时间:2024/06/05 15:39

1、

Oracle with语句是经常可以见到的语句,下面就为您详细介绍Oracle with语句的用法,如果您对Oracle with语句感兴趣的话,不妨一看。

当查询中多次用到某一部分时,可以用Oracle with语句创建一个公共临时表。因为子查询在内存临时表中,避免了重复解析,所以执行效率会提高不少。临时表在一次查询结束自动清除。

一般语法格式:

  1. with   
  2. alias_name1 as    (subquery1),  
  3. alias_name2 as    (subQuery2),  
  4. ……  
  5. alias_nameN as    (subQueryN)  
  6. select col1,col2…… col3   
  7.      from alias_name1,alias_name2……,alias_nameN 

Oracle with语句的例子:

  1. SQL> WITH  
  2. Q1 AS (SELECT 3 + 5 S FROM DUAL),  
  3.     Q2 AS (SELECT 3 * 5 M FROM DUAL),  
  4.     Q3 AS (SELECT S, M, S + M, S * M FROM Q1, Q2)  
  5. SELECT * FROM Q3; 

输出结果:

  1. S M S+M S*M  
  2. ---------- ---------- ---------- ----------  
  3. 8 15 23 120  
2、with 语句和时间

         有时候我们需要查询出过去几天的数据,然后展示出来,那么使用with语句如何实现呢?

         with t1 as (select to_date(‘sysdate’,'yyyy-mm-dd')-level+1  d from dual connect by  level<? order by d
         select aa
           from t1 left join tb_member t2 on to_date(to_char(t1.d,'YYYY-mm-dd'),'yyyy-mm-dd')<t2.regist_time
          group by to_char(t1.d,'YYYY-mm-dd') order by to_date(to_char(t1.d,'YYYY-mm-dd'),'yyyy-mm-dd'

  其中的select后面是要查询的属性,?为要查询的天数

0 0