有现成  sql server 的存储过程来实现,但是贴到oracle里面完全出错了,
oracle 里面 如何写 ?这是 sql的:
DECLARE @var_sql1 VARCHAR(max),@var_sql2 VARCHAR(max),@var_sql3 VARCHAR(max),@var_sql4 VARCHAR(max),@var_group VARCHAR(200) ,
@var_parm1 VARCHAR(max),@var_parm2 VARCHAR(max),
@var_parm3 VARCHAR(max),@var_group1 VARCHAR(200),@date_lyearbegin DATETIME,
@date_lyearend DATETIME,@date_lmonthbegin DATETIME,@date_lmonthend DATETIME--参数解析
--同期的时间SET @date_lyearbegin = DATEADD(year,-1,CAST (SUBSTRING(@var_parm,charindex('a.dsate_out,120) >= ',@var_parm)+20,10) AS DATETIME))
SET @date_lyearend = DATEADD(year,-1,CAST (SUBSTRING(@var_parm,charindex('a.dsate_out,120) <= ',@var_parm)+20,10) AS DATETIME))--环比的时间
SET @date_lmonthbegin = DATEADD(month,-1,CAST (SUBSTRING(@var_parm,charindex('a.dsate_out,120) >= ',@var_parm)+20,10) AS DATETIME))
SET @date_lmonthend = DATEADD(month,-1,CAST (SUBSTRING(@var_parm,charindex('a.dsate_out,120) <= ',@var_parm)+20,10) AS DATETIME))--同期的参数
SET @var_parm2 =SUBSTRING(@var_parm,0,charindex('a.dsate_out,120) >= ',@var_parm)+20) +convert(varchar(10),@date_lyearbegin,120)+''' '
+ SUBSTRING(@var_parm,charindex('a.dsate_out,120) >= ',@var_parm)+32,LEN(' and convert(varchar(10),a.dsate_out,120) <= ')+1) +convert(varchar(10),@date_lyearend,120) + ''' ' + SUBSTRING(@var_parm,charindex('a.dsate_out,120) <= ',@var_parm)+32,999)--环比的参数
SET @var_parm3 =SUBSTRING(@var_parm,0,charindex('a.dsate_out,120) >= ',@var_parm)+20) +convert(varchar(10),@date_lmonthbegin,120) +''' '
+ SUBSTRING(@var_parm,charindex('a.dsate_out,120) >= ',@var_parm)+32,LEN(' and convert(varchar(10),a.dsate_out,120) <= ')+1) +convert(varchar(10),@date_lmonthend,120) + ''' ' + SUBSTRING(@var_parm,charindex('a.dsate_out,120) <= ',@var_parm)+32,999)oracle

解决方案 »

  1.   

    查了一下  很多函数 都需要替换   to_char  charindex   都不一样
      

  2.   

    我取出来的数据item       qty        qty同期         qty当年上月(环比)001         2     002         2003         3我想查  001   002  003 的同期 环比
      

  3.   

    通过当前lag() over()函数 来实现当前值与一值的比较同期lag() over(order by item)
    环比lag() over(partition by 分组字段 order by item)
      

  4.   

    写一个简单的例子  大致就这样了
    with t1 as
    (
         select '001' item,2 qty,date'2012-01-01' dt from dual union all
         select '002' item,2 qty,date'2012-02-01' dt from dual union all
         select '003' item,3 qty,date'2012-03-01' dt from dual union all
         select '001' item,5 qty,date'2013-01-01' dt from dual union all
         select '002' item,4 qty,date'2013-02-01' dt from dual union all
         select '003' item,6 qty,date'2013-03-01' dt from dual union all
         select '001' item,1 qty,date'2014-01-01' dt from dual
    )select item,qty,
           lag(qty) over(order by dt) s_qty,
           lag(qty) over(partition by item,to_char(dt,'mm') order by to_char(dt,'yyyy')) h_qty
    from t1     item    qty  s_qty  h_qty   
    ----------------------------------------
    1 001 2
    2 002 2 2
    3 003 3 2
    4 001 5 3 2
    5 002 4 5 2
    6 003 6 4 3
    7 001 1 6 5
      

  5.   

    1 写存储过程完成 把PL/SQL语法学完,不要想着直接改,2 直接用窗口函数搞定,如楼上