ykwll 发表于 2015-9-23 07:02:43

EBS多OU和多帐套客户化总结上【转载】

EBS多OU和多帐套客户化总结上【转载】
2011-07-08 14:52
  
  转自:http://blog.iyunv.com/cunxiyuan108/article/details/6203156
  
  (一)多OU总结
  
  1.Form多OU实现
  
  1)创建一个Table,以CUX_AP_CHECK_HEADER_ALL为例
  
  2)创建Table的两个Synonym(一个不含_ALL,一个以_ALL结尾):CUX_AP_CHECK_HEADER和CUX_AP_CHECK_HEADER_ALL
  
  3)给不含_ALL的Synonym:CUX_AP_CHECK_HEADER加上组织屏蔽的策略函数
  
  dbms_rls.add_policy(object_name       => 'CUX_AP_CHECK_HEADER',
  
  policy_name       => 'ORG_SEC',
  
  policy_function => 'MO_GLOBAL.ORG_SECURITY',
  
  policy_type       =>dbms_rls.shared_context_sensitive);
  
  4)在不含_ALL的Synonym的基础上创建视图: CUX_AP_CHECK_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.Report多OU实现
  
  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_segment1VARCHAR2(150);--部门段
  
  BEGIN
  
  SELECT o3.attribute5
  
  INTO l_segment1
  
  FROM hr_all_organization_units   o,
  
  hr_all_organization_units_tlotl,
  
  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.Interface多OU总结
  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
  (二)多帐套总结
  1.   客户化开发中的多帐套屏蔽
  1)得到当前OU的值。
  使用:mo_global.get_current_org_id或者fnd_global.org_id
  2)根据组织id得到帐套id和公司名称。SQL语句为:
  DECLARE
  l_org_information3 VARCHAR2(150);--帐套id
  l_company_desc   VARCHAR2(150);--公司中文描述
  BEGIN
  SELECT o3.org_information3,o3.attribute3
  INTO l_org_information3,l_company_desc
  FROM hr_all_organization_units    o,
  hr_all_organization_units_tl otl,
  hr_organization_informationo2,
  hr_organization_informationo3
  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 otl.language      = USERENV('LANG')
  AND o.organization_id   = &p_org_id;--OU id
  END;
  3)得到本位币,SQL语句为:
  DECLARE
  l_local_currency_code VARCHAR2(15);--本位币
  BEGIN
  SELECT gsob.currency_code
  INTO l_local_currency_code
  FROM gl_sets_of_books gsob, hr_operating_units hou
  WHERE gsob.set_of_books_id = hou.set_of_books_id
  AND   hou.organization_id= &p_org_id;--OU ID
  END;
  4)在程序中加上帐套和本位币的限制
  2.   多帐套实现扩展
  1)得到帐套的SQL语句为:
  SELECT * FROM gl_ledgers;
  2)得到法人的SQL语句为:
  SELECT * FROM xle_entity_profiles;
页: [1]
查看完整版本: EBS多OU和多帐套客户化总结上【转载】