自動生成form Scripts

運行腳本:sql

begin
            xxx_plsql_generator_pkg2.form_view_iud_p(p_block_name  =>'CONTRACT_T'
                                                   ,p_table_name  =>'WPC_Contract_T'
                                                   ,p_owner       =>'apps'
                                                   ,p_primary_key =>'FConId');
end;

select *
        from all_tab_columns tc
       where tc.table_name = upper('cux_dis_return_ifc')
         and tc.owner = upper('apps')
         and tc.column_name = upper('FConId');
執行腳本

  調用的pckage:api

create or replace package xxx_plsql_generator_pkg is
  /*==================================================
    Copyright (C) LYR Consulting Co., Ltd 
    All rights reserved
  ===================================================*/
  -- Author  : luoyuren
  -- Created : 2010-12-07
  -- Purpose : Auto Generat Plsql Code
  g_exception exception;

  /******************************************************************
  
  IN
     p_block_name  Form中數據塊的名稱
     p_table_name  須要進行操做的數據表
     p_owner       數據表的owner
     p_primary_key 數據表的主鍵
  
  DESCEIPTOIN
     此過程主要用來生成基於視圖的數據塊經常使用觸發器ON-INSERT,
     ON-UPDATE,ON-DELETE,ON-LOCK之代碼,使用時採用PL/SQL Developer
     開發工具的的Test Windows,代碼執行完成後會在DBMS Output標籤頁
     中輸出相關代碼,使用時將代碼Copy至Oralce Form Builder的Program
     Units中,分爲Package Spec和Package Body,並在相應觸發器中加入相
     應引用代碼;
  
  ***************************************************************/ 
  procedure form_view_iud_p(p_block_name  in varchar2
                           ,p_table_name  in varchar2
                           ,p_owner       in varchar2
                           ,p_primary_key in varchar2);

end xxx_plsql_generator_pkg;
/
create or replace package body xxx_plsql_generator_pkg is
  /*==================================================
    Copyright (C) LYR Consulting Co., Ltd 
    All rights reserved
  ===================================================*/
  g_output_first boolean := false;
  g_cp_flag      number; -- conc program
  g_newline      varchar2(1) := chr(10);

  type column_rec_type is record(
    column_name varchar2(30),
    nullable    varchar2(1));

  type column_tbl_type is table of column_rec_type index by binary_integer;

  procedure output_msg(p_msg_data in varchar2) is
  begin
    if g_output_first = false
    then
      g_cp_flag := fnd_profile.value('CONC_REQUEST_ID');
      if g_cp_flag > 0
      then
        null;
      else
        dbms_output.enable(buffer_size => 20000000);
      end if;
    end if;
  
    if (g_cp_flag > 0)
    then
      fnd_file.put_line(fnd_file.log
                       ,p_msg_data);
    else
      dbms_output.put_line(p_msg_data);
    end if;
  exception
    when others then
      null;
  end output_msg;


  procedure form_view_iud_p(p_block_name  in varchar2
                           ,p_table_name  in varchar2
                           ,p_owner       in varchar2
                           ,p_primary_key in varchar2) is
    cursor c_table is
      select 'Y'
        from all_tables t
       where t.table_name = upper(p_table_name)
         and t.owner = upper(p_owner);
  
    cursor c_tabcol is
      select 'Y'
        from all_tab_columns tc
       where tc.table_name = upper(p_table_name)
         and tc.owner = upper(p_owner)
         and tc.column_name = upper(p_primary_key);
  
    cursor c_sequence is
      select 'Y'
        from all_objects ao
       where ao.owner = p_owner
         and ao.object_type = 'SEQUENCE'
         and ao.object_name = upper(p_table_name) || '_S';
  
    cursor c_columns is
      select tc.column_name
            ,tc.nullable
        from all_tab_columns tc
       where tc.table_name = upper(p_table_name)
         and tc.owner = upper(p_owner)
       order by tc.column_id;
  
    l_dummy          varchar2(1);
    l_msg_data       varchar2(4000);
    l_package_name   varchar2(100);
    l_block_name_ext varchar2(50) := ':' || upper(p_block_name) || '.';
    l_rec_ext        varchar2(30) := 'rec.';
  
    l_column_tbl   column_tbl_type;
    l_column_count number := 0;
  
  begin
  
    if (p_block_name is null) or
       (p_table_name is null) or
       (p_owner is null) or
       (p_primary_key is null)
    then
      l_msg_data := 'Parameter not allow null !';
      raise fnd_api.g_exc_error;
    end if;
  
    -- check table exists
    open c_table;
    fetch c_table
      into l_dummy;
    if c_table%notfound
    then
      close c_table;
      l_msg_data := 'Table ' || upper(p_table_name) || ' not found !';
      raise fnd_api.g_exc_error;
    end if;
    close c_table;
  
    --check primary_key exists
    open c_tabcol;
    fetch c_tabcol
      into l_dummy;
    if c_tabcol%notfound
    then
      close c_tabcol;
      l_msg_data := 'Table ' || upper(p_table_name) ||
                    ' not exists column ' || upper(p_primary_key) || ' !';
      raise fnd_api.g_exc_error;
    end if;
    close c_tabcol;
  
    --check sequence exists
    /*Open c_sequence;
    Fetch c_sequence
      Into l_dummy;
    If c_sequence%Notfound Then
      Close c_sequence;
      l_msg_data := 'Sequence ' || upper(p_block_name) || '_S not exists !';
      Raise fnd_api.g_exc_error;
    End If;
    Close c_sequence;*/
  
    -- get columns
    for r in c_columns
    loop
      l_column_count := l_column_count + 1;
      l_column_tbl(l_column_count).column_name := r.column_name;
      l_column_tbl(l_column_count).nullable := r.nullable;
    end loop;
  
    if l_column_count < 1
    then
      l_msg_data := 'Not column in table ' || p_table_name;
      raise fnd_api.g_exc_error;
    end if;
  
    l_package_name := upper(p_block_name) || '_PKG';
    -- generate package special
    l_msg_data := 'PACKAGE ' || l_package_name || ' IS' || g_newline ||
                  g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '/*===============================================================' ||
                  g_newline ||
                  '*   Copyright (C) LYR Consulting Co., Ltd All rights reserved' ||
                  g_newline ||
                  '* ===============================================================' ||
                  g_newline || '*    Program Name:' || l_package_name;
  
    output_msg(l_msg_data);
  
    l_msg_data := '*    Author      :' || g_newline || '*    Date        :' ||
                  g_newline || '*    Purpose     :' || g_newline ||
                  '*    Parameters  :' || g_newline ||
                  '*    Update History' || g_newline ||
                  '*    Version    Date         Name            Description' ||
                  g_newline ||
                  '*    --------  ----------  ---------------  --------------------';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*     V1.0                                   Creation    ' ||
                  g_newline || '*' || g_newline ||
                  '  ===============================================================*/' ||
                  g_newline;
  
    output_msg(l_msg_data);
  
    l_msg_data := '  PROCEDURE insert_row;' || g_newline ||
                  '  PROCEDURE lock_row;' || g_newline ||
                  '  PROCEDURE update_row;' || g_newline ||
                  '  PROCEDURE delete_row;' || g_newline || g_newline ||
                  'END ' || l_package_name || ';' || g_newline;
  
    output_msg(l_msg_data);
  
    -- generate package body
    -- begin
    l_msg_data := 'PACKAGE BODY ' || l_package_name || ' IS' || g_newline;
    output_msg(l_msg_data);
  
    -- insert row
  
    /*
    l_msg_data := '\*=====================================' || g_newline || '** PROCEDURE:  insert_row()' || g_newline ||
                  '**=====================================*\' || g_newline || 'PROCEDURE insert_row IS' || g_newline;
                  */
  
    l_msg_data := '/*===============================================================' ||
                  g_newline || '*    Program Name:insert_row()' ||
                  g_newline || '*    Author      :' || g_newline ||
                  '*    Date        :' || g_newline || '*    Purpose     :' ||
                  g_newline || '*    Parameters  :' || g_newline ||
                  '*             In       X     --X的說明';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*             Out      Y     --Y的說明' || g_newline ||
                  '*    Update History' || g_newline ||
                  '*    Version    Date         Name            Description' ||
                  g_newline ||
                  '*    --------  ----------  ---------------  --------------------';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*     V1.0                                   Creation    ' ||
                  g_newline || '*' || g_newline ||
                  '  ===============================================================*/' ||
                  g_newline || 'PROCEDURE insert_row IS';
  
    output_msg(l_msg_data);
  
    l_msg_data := '  CURSOR row_id' || g_newline || '  IS    SELECT ROWID' ||
                  g_newline || '       FROM ' || p_table_name || g_newline ||
                  '      WHERE ' || p_primary_key || ' = ' ||
                  l_block_name_ext || p_primary_key || ';' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := 'BEGIN' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  fnd_standard.set_who;' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  IF ' || l_block_name_ext || p_primary_key ||
                  ' IS NULL THEN' || g_newline || '    SELECT ' ||
                  upper(p_table_name) || '_S.NEXTVAL' || g_newline ||
                  '      INTO ' || l_block_name_ext || p_primary_key ||
                  g_newline || '      FROM SYS.DUAL;' || g_newline ||
                  '  END IF;' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  INSERT INTO ' || p_table_name || ' (';
    output_msg(l_msg_data);
    for i in 1 .. l_column_count
    loop
      if i = l_column_count
      then
        l_msg_data := '     ' || l_column_tbl(i).column_name || ')';
      else
        l_msg_data := '     ' || l_column_tbl(i).column_name || ',';
      end if;
      output_msg(l_msg_data);
    end loop;
    l_msg_data := '  VALUES (';
    output_msg(l_msg_data);
    for i in 1 .. l_column_count
    loop
      if i = l_column_count
      then
        l_msg_data := '     ' || l_block_name_ext || l_column_tbl(i)
                     .column_name || ');' || g_newline;
      else
        l_msg_data := '     ' || l_block_name_ext || l_column_tbl(i)
                     .column_name || ',';
      end if;
      output_msg(l_msg_data);
    end loop;
  
    l_msg_data := '  OPEN row_id;' || g_newline || '  FETCH row_id INTO ' ||
                  l_block_name_ext || 'ROW_ID;' || g_newline ||
                  '  IF (row_id%NOTFOUND) THEN' || g_newline ||
                  '     CLOSE row_id;' || g_newline ||
                  '     RAISE NO_DATA_FOUND;' || g_newline || '  END IF;' ||
                  g_newline || '  CLOSE row_id;' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := 'END insert_row;' || g_newline;
    output_msg(l_msg_data);
  
    -- lock row
  
    --l_msg_data := '\*=====================================' || g_newline || '** PROCEDURE:  lock_row()' || g_newline ||
    --              '**=====================================*\' || g_newline || 'PROCEDURE lock_row IS' || g_newline;
  
    l_msg_data := '/*===============================================================' ||
                  g_newline || '*    Program Name:lock_row()' || g_newline ||
                  '*    Author      :' || g_newline || '*    Date        :' ||
                  g_newline || '*    Purpose     :' || g_newline ||
                  '*    Parameters  :' || g_newline ||
                  '*             In       X     --X的說明';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*             Out      Y     --Y的說明' || g_newline ||
                  '*    Update History' || g_newline ||
                  '*    Version    Date         Name            Description' ||
                  g_newline ||
                  '*    --------  ----------  ---------------  --------------------';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*     V1.0                                   Creation    ' ||
                  g_newline || '*' || g_newline ||
                  '  ===============================================================*/' ||
                  g_newline || 'PROCEDURE lock_row IS';
  
    output_msg(l_msg_data);
  
    l_msg_data := '  CURSOR c_row' || g_newline || '  IS SELECT *' ||
                  g_newline || '       FROM ' || p_table_name || g_newline ||
                  '      WHERE rowid = ' || l_block_name_ext || 'ROW_ID' ||
                  g_newline || '      FOR UPDATE OF ' || p_primary_key ||
                  ' NOWAIT;' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  rec     c_row%rowtype;' || g_newline ||
                  '  i NUMBER := 0;' || g_newline || 'BEGIN' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  LOOP' || g_newline || '    BEGIN';
    output_msg(l_msg_data);
  
    l_msg_data := '      i := i + 1;' || g_newline || '      OPEN c_row;' ||
                  g_newline || '      FETCH c_row INTO rec;';
    output_msg(l_msg_data);
  
    l_msg_data := '      IF (c_row%NOTFOUND) THEN' || g_newline ||
                  '        CLOSE c_row;' || g_newline ||
                  '        fnd_message.set_name(''FND'',''FORM_RECORD_DELETED'');' ||
                  g_newline || '        fnd_message.error;' || g_newline ||
                  '        RAISE FORM_TRIGGER_FAILURE;';
    output_msg(l_msg_data);
  
    l_msg_data := '      END IF;' || g_newline || '      CLOSE c_row;' ||
                  g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '      IF (';
    output_msg(l_msg_data);
    for i in 1 .. l_column_count
    loop
      if i = 1
      then
        l_msg_data := '              ';
      else
        l_msg_data := '          AND ';
      end if;
      if l_column_tbl(i).column_name = p_primary_key
      then
        l_msg_data := l_msg_data || '(' || l_rec_ext || l_column_tbl(i)
                     .column_name || ' = ' || l_block_name_ext ||
                      l_column_tbl(i).column_name || ')';
      else
        l_msg_data := l_msg_data || '((' || l_rec_ext || l_column_tbl(i)
                     .column_name || ' = ' || l_block_name_ext ||
                      l_column_tbl(i)
                     .column_name || ') OR' || g_newline ||
                      '               ((' || l_rec_ext || l_column_tbl(i)
                     .column_name || ' IS NULL)' || ' AND (' ||
                      l_block_name_ext || l_column_tbl(i)
                     .column_name || ' IS NULL)))';
      end if;
      output_msg(l_msg_data);
    end loop;
  
    l_msg_data := '      ) THEN' || g_newline || '        RETURN;' ||
                  g_newline || '      ELSE' || g_newline ||
                  '        fnd_message.set_name(''FND'', ''FORM_RECORD_CHANGED'');' ||
                  g_newline || '        fnd_message.error;' || g_newline ||
                  '        RAISE FORM_TRIGGER_FAILURE;' || g_newline ||
                  '      END IF;' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '    EXCEPTION' || g_newline ||
                  '      WHEN app_exception.record_lock_exception THEN' ||
                  g_newline ||
                  '        app_exception.record_lock_error(i);' ||
                  g_newline || '    END;' || g_newline || '  END LOOP;' ||
                  g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := 'END lock_row;' || g_newline;
    output_msg(l_msg_data);
  
    -- update row
    l_msg_data := '/*===============================================================' ||
                  g_newline || '*    Program Name:update_row()' ||
                  g_newline || '*    Author      :' || g_newline ||
                  '*    Date        :' || g_newline || '*    Purpose     :' ||
                  g_newline || '*    Parameters  :' || g_newline ||
                  '*             In       X     --X的說明';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*             Out      Y     --Y的說明' || g_newline ||
                  '*    Update History' || g_newline ||
                  '*    Version    Date         Name            Description' ||
                  g_newline ||
                  '*    --------  ----------  ---------------  --------------------';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*     V1.0                                   Creation    ' ||
                  g_newline || '*' || g_newline ||
                  '  ===============================================================*/' ||
                  g_newline || 'PROCEDURE update_row IS';
  
    output_msg(l_msg_data);
  
    l_msg_data := 'BEGIN' || g_newline;
    output_msg(l_msg_data);
    l_msg_data := '  fnd_standard.set_who;' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  UPDATE ' || p_table_name || ' SET';
    output_msg(l_msg_data);
    for i in 1 .. l_column_count
    loop
      l_msg_data := '      ' || rpad(l_column_tbl(i).column_name
                                    ,30) || ' = ' || l_block_name_ext ||
                    l_column_tbl(i).column_name;
      if i < l_column_count
      then
        l_msg_data := l_msg_data || ',';
      end if;
      output_msg(l_msg_data);
    end loop;
    l_msg_data := '  WHERE ROWID = ' || l_block_name_ext || 'ROW_ID;' ||
                  g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  IF (SQL%NOTFOUND) THEN' || g_newline ||
                  '     RAISE NO_DATA_FOUND;' || g_newline || '  END IF;' ||
                  g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := 'END update_row;' || g_newline;
    output_msg(l_msg_data);
  
    -- delete row
  
    --l_msg_data := '\*=====================================' || g_newline || '** PROCEDURE:  delete_row()' || g_newline ||
    --                  '**=====================================*\' || g_newline || 'PROCEDURE delete_row IS';
  
    l_msg_data := '/*===============================================================' ||
                  g_newline || '*    Program Name:delete_row()' ||
                  g_newline || '*    Author      :' || g_newline ||
                  '*    Date        :' || g_newline || '*    Purpose     :' ||
                  g_newline || '*    Parameters  :' || g_newline ||
                  '*             In       X     --X的說明';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*             Out      Y     --Y的說明' || g_newline ||
                  '*    Update History' || g_newline ||
                  '*    Version    Date         Name            Description' ||
                  g_newline ||
                  '*    --------  ----------  ---------------  --------------------';
  
    output_msg(l_msg_data);
  
    l_msg_data := '*     V1.0                                   Creation    ' ||
                  g_newline || '*' || g_newline ||
                  '  ===============================================================*/' ||
                  g_newline || 'PROCEDURE delete_row IS';
  
    output_msg(l_msg_data);
  
    l_msg_data := 'BEGIN' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  DELETE FROM ' || p_table_name || g_newline ||
                  '  WHERE ' || p_primary_key || ' = ' || l_block_name_ext ||
                  p_primary_key || ';' || g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := '  IF (SQL%NOTFOUND) THEN' || g_newline ||
                  '     RAISE NO_DATA_FOUND;' || g_newline || '  END IF;' ||
                  g_newline;
    output_msg(l_msg_data);
  
    l_msg_data := 'END delete_row;' || g_newline;
    output_msg(l_msg_data);
  
    -- end
    l_msg_data := 'END ' || l_package_name || ';';
    output_msg(l_msg_data);
  
  exception
    when fnd_api.g_exc_error then
      output_msg(l_msg_data);
    when others then
      output_msg(sqlerrm);
  end form_view_iud_p;

end xxx_plsql_generator_pkg;
/
相關文章
相關標籤/搜索