zoukankan      html  css  js  c++  java
  • ORACLE EBS 多OU总结

    1.  FormOU实现

    1)  创建一个Table,以CUX_OM_ORDER_HEADER_ALL为例

    2)  创建Table的两个Synonym(一个不含_ALL,一个以_ALL结尾):CUX_OM_ORDER_HEADER和CUX_OM_ORDER_HEADER_ALL

    3)  给不含_ALL的Synonym:CUX_OM_ORDER_HEADER加上组织屏蔽的策略函数

    dbms_rls.add_policy(object_name     => 'CUX_OM_ORDER_HEADER',
                        policy_name     => 'ORG_SEC',
                        policy_function => 'MO_GLOBAL.ORG_SECURITY',
                        policy_type     =>  dbms_rls.shared_context_sensitive);

    4)  在不含_ALL的Synonym的基础上创建视图: CUX_OM_ORDER_HEADER_V

    5)  进入FORM时(pre-form触发器)添加代码:

    mo_global.init(p_appl_shortname);  --p_appl_shortname为应用简称

    6)  当选择某个OU时(一般在when_validate_item触发器)中添加代码:mo_global.set_policy_context('S',p_org_id);  --p_org_id为OU的id

    2.  ReportOU实现

    1)  给并发程序设置业务实体模式:单个,多个和空(默认)。一般设置为‘单个’

    业务实体模式对应表fnd_concurrent_programs中的multi_org_category字段

    2)  得到当前OU的值。

    使用:mo_global.get_current_org_id或者fnd_global.org_id

    3)  在报表的参数和报表的逻辑中加上OU的限制

    3.  GL数据的多OU实现

    1)  得到当前OU的值。

    使用:mo_global.get_current_org_id或者fnd_global.org_id

    2)  根据OU的值得到部门段的值:

    DECLARE
      l_segment1 VARCHAR2(150); --公司段
    BEGIN
      SELECT o3.attribute1
        INTO l_segment1
        FROM hr_all_organization_units o,
             hr_all_organization_units_tl otl,
             hr_organization_information o2,
             hr_organization_information o3
       WHERE o.organization_id = o2.organization_id
         AND o.organization_id = o3.organization_id
         AND o2.org_information_context = 'CLASS'
         AND o3.org_information_context = 'Operating Unit Information'
         AND o2.org_information1 = 'OPERATING_UNIT'
         AND o2.org_information2 = 'Y'
         AND o.organization_id = otl.organization_id
         AND o.organization_id = &p_org_id   --ou id
         AND otl.language = userenv('LANG');
    END;

    3)  将步骤2得到的值作为限制条件:

    SELECT gl_code_combinations gcc WHERE gcc.segment1 = l_segment1;

    4.  InterfaceOU总结

    1)  给并发程序设置业务实体模式:单个,多个和空(默认)。业务实体模式对应表fnd_concurrent_programs中的multi_org_category字段

    2)  如果接口的导入程序中OU作为一个参数,则应该将所有的OU作一次循环。

    5.  OU实现扩展知识

    1)  给客户化应用注册和取消MOAC的控制

    fnd_mo_product_init_pkg.register_application(注册应用)

    fnd_mo_product_init_pkg.register_application(取消应用)

    查看支持MOAC的应用SQL:

    SELECT * FROM fnd_mo_product_init;

    2)  给数据库对象注册和取消策略-policy

    dbms_rls.add_policy(注册策略)

    dbms_rls.drop_policy(取消策略)

    3)  多OU 涉及到的表

    a)   查看数据库对象是否增加了策略-policy

    SELECT * FROM dba_policies;

    b)   查看当前session所能访问的OU

    SELECT * FROM mo_glob_org_access_tmp;

    c)   查看当前session应用上下文(context)的值(说明:OU的值保存在context中)

    SELECT * FROM dba_context dc WHERE dc.namespace LIKE 'MULTI%';

    MOAC使用的应用程序上下文:MULTI_ORG,MULTI_ORG2

  • 相关阅读:
    学习素材、网站
    用 Python脚本生成 Android SALT 扰码
    H面试程序(29):求最大递增数
    常用数据库查询判断表和字段是否存在
    《火球——UML大战需求分析》(第3章 分析业务模型-类图)——3.7 关于对象图
    N个数依次入栈,出栈顺序有多少种
    WIN ERROR:C:WindowsSystem32<LANG_NAME>mstsc.exe.MUI
    大端法和小端法
    freopen()重定向的打开和关闭
    Linux 的 Spinlock 在 MIPS 多核处理器中的设计与实现
  • 原文地址:https://www.cnblogs.com/Cqiang/p/2946091.html
Copyright © 2011-2022 走看看