EBS开发_Form多OU的实现

本文档详细介绍了在Oracle E-Business Suite (EBS) 中,如何通过创建Table Synonym、设置组织策略函数、创建视图以及在FORM级别处理,实现Form对多个Operating Unit (OU) 的访问控制。主要步骤包括初始化MO_GLOBAL,根据OU数量决定OU字段录入权限,并在POST-QUERY中处理OU信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Form多OU的实现

 

<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

实例如下:

 

PACKAGE BODY CUX_MOAC_PKG IS
 
   --MOAC初始化
   procedure pre_form
   is
l_default_org_id number;
l_default_ou_name varchar2(240);
l_ou_count number;
   begin
       MO_GLOBAL.init('CUX');
mo_utils.get_default_ou(l_default_org_id, l_default_ou_name, l_ou_count);
        IF l_default_org_id IS NOT NULL THEN
  copy(l_default_org_id

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值