• Oracle:动态SQL实例


    create or replace procedure FSPVIQA7_qty
    as
      var_sql   varchar2(2000);
      i         number;
      j         number;
    begin
      delete from tpt_app_qty;
      i := 1;
      while i<=5 loop
        j := 1;
        while j <= 3 loop
          var_sql := '';
          var_sql := ' insert into tpt_app_qty(tpt_flow,tpt_nbr,tpt_crt_dept,tpt_date,tpt_imp_dept,tpt_cm,tpt_cm_sort,tpt_need,tpt_opinion,tpt_n_opinion,
                                              tpt_engineer,tpt_eng_name,tpt_crt_by,tpt_crt_name)
                       select a.app_flow,a.app_nbr,a.app_dept,a.app_date,a.app_'||to_char(i)||'_dept'||',a.app_cm,cm_sort,a.app_need,'||to_char(i)||to_char(j)||',a.app_'||to_char(i)||'_summary,
                       app_'||to_char(i)||'_engineer'||to_char(j)||',u1.usr_name,app_crt_by,u.usr_name from app1_mstr a
                       left join v_erp_cust on cm_addr=app_cm
                       join usr_mstr u on u.usr_user=app_crt_by
                       join usr_mstr u1 on u1.usr_user=app_'||to_char(i)||'_engineer'||to_char(j)||
                       ' where app_'||to_char(i)||'_pst=''1''
                       and app_'||to_char(i)||'_sub'||to_char(j)||'=''0''
                       and app_'||to_char(i)||'_engineer'||to_char(j)||' is not null
                       and app_product_fee = 0
                       and not exists(select 1 from app1_mstr b where a.app_nbr = b.app_nbr and b.app_version > a.app_version)
                       union all
                       select app_flow,app_nbr,app_dept,app_date,app_'||to_char(i)||'_dept'||',app_cm,cm_sort,app_need,'||to_char(i)||to_char(j)||',app_'||to_char(i)||'_summary,
                       app_'||to_char(i)||'_engineer'||to_char(j)||',u1.usr_name,app_crt_by,u.usr_name from app1_mstr a
                       left join v_erp_cust on cm_addr=app_cm
                       join usr_mstr u on u.usr_user=app_crt_by
                       join usr_mstr u1 on u1.usr_user=app_'||to_char(i)||'_engineer'||to_char(j)||
                       ' where app_'||to_char(i)||'_pst=''1''
                       and app_work  = 1
                       and app_prog_code = ''FSPUMTA4''
                       and not exists(select 1 from app1_mstr b where a.app_nbr = b.app_nbr and b.app_version > a.app_version)';
         -- dbms_output.put_line(var_sql);
          execute immediate var_sql;
          j := j+1;
        end loop;
        i:= i+1;
      end loop;
    end FSPVIQA7_qty;
  • 相关阅读:
    Poj(1459),最大流,EK算法
    Poj(3259),SPFA,判负环
    HDU(3790),最短路二级标准
    Poj(2349),最小生成树的变形
    CSUFT2016训练赛
    NYOJ(21),BFS,三个水杯
    Poj(3687),拓扑排序,
    Poj(2367),拓扑排序
    HDU(1856),裸的带权并查集
    HDU(1572),最短路,DFS
  • 原文地址:https://www.cnblogs.com/su1643/p/6796023.html
Copyright © 2020-2023  润新知