zoukankan      html  css  js  c++  java
  • 键弹性域

    键弹性域的开发例子:
    /***************************在客户化的用户下*******************************/
    /* 键应用表 */

    create table hek_om_pop_validity_all(
      line_id                        number,
      inventory_item_id              number,      

      number_of_day                  number,         
      start_date                     date,           
      end_date                       date,           
      
       --=================扩展字段================================
      created_by                     number,
      creation_date                  date,
      last_updated_by                number,
      last_update_date               date,
      last_update_login              number,
      org_id                         number,

      attribute_category             varchar2(30),
      attribute1                     varchar2(50),
      attribute2                     varchar2(50),
      attribute3                     varchar2(50),
      attribute4                     varchar2(150),
      attribute5                     varchar2(150)
    );


    /* 创建存放键弹性域的结构表 */
    CREATE TABLE FLEX_LN_KEY
    (
      KEY_FLEX_STRUCTURE_ID  NUMBER ,
      KEY_FLEX_ID            NUMBER ,
      SUMMARY_FLAG            VARCHAR2(1) ,  /* 必须有此字段 */
      ENABLED_FLAG            VARCHAR2(1) ,  /* 必须有此字段 */
      START_DATE_ACTIVE       DATE ,         /* 必须有此字段 */
      END_DATE_ACTIVE         DATE ,  /* 必须有此字段 */
      LAST_UPDATED_BY         NUMBER ,  /* 必须有此字段 */
      LAST_UPDATE_DATE        DATE ,   /* 必须有此字段 */
      SEGMENT1                VARCHAR2(30) ,
      SEGMENT2                VARCHAR2(30) ,
      SEGMENT3                VARCHAR2(30) ,
      SEGMENT4                VARCHAR2(30) ,
      SEGMENT5                VARCHAR2(30) ,
      SEGMENT6                VARCHAR2(30) ,
      SEGMENT7                VARCHAR2(30) ,
      SEGMENT8                VARCHAR2(30) ,
      SEGMENT9                VARCHAR2(30) ,
      SEGMENT10               VARCHAR2(30) ,
      SEGMENT11               VARCHAR2(30) ,
      SEGMENT12               VARCHAR2(30) ,
      SEGMENT13               VARCHAR2(30) ,
      SEGMENT14               VARCHAR2(30) ,
      SEGMENT15               VARCHAR2(30)
    );
    /* 必须要创建一个与键结构表对应的序列 */
     CREATE SEQUENCE FLEX_LN_KEY_S   START WITH 1;  --创建存放键弹性域表的对应序列(键弹性域表名+"_S")
     grant all on T_KEY_FLEX to apps;
     grant all on FLEX_LN_KEY to apps;
     grant all on flex_ln_key_s to apps;
     
    /***************************在公共用户APPS下*******************************/
    conn apps/apps
      
    /* 创建同义词 */
       CREATE SYNONYM FLEX_LN_KEY FOR HEKFLEX_LN_KEY  ;
       CREATE SYNONYM FLEX_LN_KEY_S FOR HEK.FLEX_LN_KEY_S;
    /* 注册键结构表和字段 */
    BEGIN
     ad_dd.register_table('HEK', 'FLEX_LN_KEY', 'T');
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'KEY_FLEX_STRUCTURE_ID', 1, 'NUMBER', 38, 'Y','N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'KEY_FLEX_ID', 2, 'NUMBER', 38, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT1', 3, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT2', 4, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT3', 5, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT4', 6, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT5', 7, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT6', 8, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT7', 9, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT8', 10, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT9', 11, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT10',12, 'VARCHAR2', 30, 'Y', 'N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT11', 13, 'VARCHAR2', 30, 'Y','N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT12', 14, 'VARCHAR2', 30, 'Y','N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT13', 15, 'VARCHAR2', 30, 'Y','N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT14', 16, 'VARCHAR2', 30, 'Y','N' );
     ad_dd.register_column('HEK', 'FLEX_LN_KEY', 'SEGMENT15',17, 'VARCHAR2', 30, 'Y', 'N' );
    COMMIT;
    END;


    FORM的PRE-FORM:

    FND_KEY_FLEX.DEFINE (
    BLOCK => 'HEK_OM_POP_VALIDITY_V', -- 操作的BLOCK
    FIELD => 'KEY_FLEXITEM', -- 创建的ITEM,用来容纳键弹性域
    ID => 'LINE_ID', --保存KEY弹性域的唯一值(block的表)
    APPL_SHORT_NAME => 'HEK',
    CODE => 'TEST', -- 键弹性域的注册代码 fnd_id_flex_structures.id_flex_code
    NUM => '101' --fnd_id_flex_structures.id_flex_num
    );

    KEY_FLEXITEM属性:itemclass - TEST_ITEM,   LOV选择ENABLE_LIST_LAMP,检查有效性否。

    分别在BLOCK级别加入如下的触发器(可参考说明性弹性域的应用代码).
    PRE-QUERY
    PRE-UPDATE
    PRE-INSERT
    POST-QUERY
    WHEN-NEW-ITEM-INSTANCE
    WHEN-VALIDATE-ITEM
    WHEN-VALIDATE-RECORD
    其触发器的代码分别对应
         FND_FLEX.EVENT('PRE-QUERY ');
         FND_FLEX.EVENT('PRE-UPDATE ');
         FND_FLEX.EVENT('PRE-INSERT ');
         FND_FLEX.EVENT('POST-QUERY ');
         FND_FLEX.EVENT('WHEN-NEW-ITEM-INSTANCE');
         FND_FLEX.EVENT('WHEN-VALIDATE-ITEM');
         FND_FLEX.EVENT('WHEN-VALIDATE-RECORD');


    注册键弹性域

        应用:选择注册的应用
            代码:填写注册键弹性域的CODE(必须唯一,最多四个字符,在调用键弹性域必须使用的值)
            标题:键弹性域的标题,在今后的应用中,此键弹性域将会在窗口标题上显示在此定义的标题内容
            说明:
            表应用:在注册表,列时指定的应用(appl_short_name)
            表名:  选择注册的表名称
            结构列:必须也是存在于注册过的列,结构列的意义就是存放键弹性域使用的是哪个段结构的代码
            唯一标识列:是记录键弹性域唯一的值,要找到健弹性域的具体含义,必须通过此唯一标识列

    定义键弹性域的段结构


    备注说明:
    /******************
    键弹性域的数据字典
    ******************/
    SELECT * FROM FND_ID_FLEXS where  id_flex_code='TEST';
    SELECT * FROM FND_ID_FLEX_SEGMENTS_TL where  id_flex_code='TEST';
    SELECT * FROM FND_ID_FLEX_SEGMENTS WHERE id_flex_code='TEST';
    SELECT * FROM Fnd_Id_Flex_Structures where id_flex_code='TEST';
    SELECT * FROM FND_ID_FLEX_STRUCTURES_TL  where id_flex_code='TEST';
    /*************************
    完全删除键弹性域的语法
    *************************/
    --删除键弹性域的结构段
    DELETE FND_ID_FLEX_SEGMENTS_VL WHERE ID_FLEX_CODE = ?;
    --删除键弹性域的结构
    DELETE FND_ID_FLEX_STRUCTURES_VL WHERE ID_FLEX_CODE = ?;
    --删除键弹性注册
    DELETE  FND_ID_FLEXS WHERE ID_FLEX_CODE = ?;


    效果:

    -----------------------------------------------------------------------------------

    补充:

    PRE-FORM

    --会计科目
    SELECT chart_of_accounts_id
      INTO :parameter.chart_of_accounts_id
      FROM org_organization_definitions
     WHERE organization_id = :parameter.org_id;

     FND_KEY_FLEX.DEFINE(BLOCK=>'CUX_INV_BCP_GANOH',
                        FIELD=>'TO_ACCOUNT',
                        ID=>'TO_ACCOUNT_ID',
                        APPL_SHORT_NAME=>'SQLGL',
                        CODE=>'GL#',
                        NUM=>':PARAMETER.CHART_OF_ACCOUNTS_ID',
                        VRULE=> '\\nSUMMARY_FLAG\\nI\\nAPPL=SQLGL;NAME=GL_NO_PARENT_SEGMENT_ALLOWED\\nN\\0GL_GLOBAL\\nDETAIL_POSTING_ALLOWED\\nE\\nAPPL=INV;NAME=INV_VRULE_POSTING\\nN',
                        USEDBFLDS=> 'N',
                        VALIDATE=>'FULL',
                        REQUIRED=>'N');
     FND_KEY_FLEX.UPDATE_DEFINITION(BLOCK=>'CUX_INV_BCP_GANOH',
          FIELD=>'TO_ACCOUNT',
          ENABLED=>'N');

  • 相关阅读:
    【每日一题-leetcode】98.验证二叉搜索树
    python第11天——核心篇3
    python第十天-核心篇2
    光盘文件传输到U盘的问题
    python第九天-核心篇1
    python第八天-飞机大战
    python第7天
    如何解决长时间写代码的颈椎等问题
    python第六天
    python第五天
  • 原文地址:https://www.cnblogs.com/benio/p/1619452.html
Copyright © 2011-2022 走看看