详细内容需要参考文档:Oracle 11i Advanced Pricing—Don’t Customize, Extend!

utl:http://blog.csdn.net/cai_xingyun/article/details/41384541

Oracle Advanced Pricing - Version 11.5.8 and later

Information in this document applies to any platform.

***Checked for relevance on 06-DEC-2013***

PURPOSE

This note explains details on sourcing Pricing Attributes by implementing QP_CUSTOM_SOURCE.Get_Custom_Attribute_Values procedure and troubleshooting custom sourced attributes.

QUESTIONS AND ANSWERS

Using Custom Sourced Attributes

Attributes can also be passed to the pricing engine directly, without the need for an attribute mapping rule. In such cases, the Attribute Manager API calls the QP_CUSTOM_SOURCE API, where the user has manually
defined the attributes being passed and coded the sourcing of their values.



The user code is written in the package procedure QP_CUSTOM_SOURCE.Get_Custom_Attribute_Values. 

The Attribute Manager API program (Build_Contexts), calls this procedure to pick up custom-sourced attributes if the profile option QP: Custom Sourced is set to Yes. The input parameters to QP_CUSTOM_SOURCE are Request Type code and Pricing Type. Typical values
of Request Type Codes that can be passed are ONT, ASO, OKC, IC, FTE or MSD. By using the Request_Type_Code, the user can control how the attributes are sourced based on the PTE of the calling application.



The Pricing Type can be H (Header) or L (Line) which defines the level of the attribute mapping rule. These attributes and their values are passed to the pricing engine in the same manner as the attributes sourced through attribute mapping rules.



Profile option:

QP: Custom Sourced - Yes 



Files:

a. QPXCSOUS.pls - QP_CUSTOM_SOURCE Package Specification. 

b. QPXCSOUB.pls - QP_CUSTOM_SOURCE Package Body.

Customer has to implement the Package Body in QPXCSOUB.pls (for example) to source custom mapped qualifier/pricing attributes in Get_Custom_Attribute_Values procedure and need to set QP: Custom Sourced profile option
value to Yes.



Procedure Get_Custom_Attribute_Values:

QPXCSOUS.pls - QP_CUSTOM_SOURCE package specification contains the following procedure declaration. 

PROCEDURE Get_Custom_Attribute_Values 

( p_req_type_code IN VARCHAR2 

, p_pricing_type_code IN VARCHAR2 

, x_qual_ctxts_result_tbl OUT QP_ATTR_MAPPING_PUB.CONTEXTS_RESULT_TBL_TYPE 

, x_price_ctxts_result_tbl OUT QP_ATTR_MAPPING_PUB.CONTEXTS_RESULT_TBL_TYPE 

); 

Parameters: 

p_req_type_code - Request Type Code. ex, ONT. 

p_pricing_type_code - 'L' for Line and 'H' for Header Level attribute mapping rule. 

x_qual_ctxts_result_tbl - Qualifier attributes result table. 

x_price_ctxts_result_tbl - Pricing attributes result table.

If profile option QP: Custom Sourced is set to Yes, Attribute Manager API Build_Contexts will call QP_CUSTOM_SOURCE.Get_Custom_Attribute_Values procedure to source custom mapped attributes. ie, attributes with attribute
Attribute Mapping Method=CUSTOM SOURCED.

Example code: 

The following example explains how a customer may code the body of QP_CUSTOM_SOURCE for a particular case. 

In this case, two segment mapping columns, 'QUALIFIER_ATTRIBUTE31' and 'PRICING_ATTRIBUTE31' that belong to contexts CUST_SOURCE_QUAL_CON and CUST_SOURCE_PRIC_CON respectively and linked to PTE 'Order Fulfillment', will have Custom Sourced values as 10 for
ORDER as well as LINE Attribute Mapping levels. The user must ensure that the Attribute Mapping method for both these PTE-Attribute links is CUSTOM SOURCED in the 'Attribute Linking and Mapping' setup window. 

CREATE or REPLACE PACKAGE body QP_CUSTOM_SOURCE AS 

/*Customizable Public Procedure*/ 

PROCEDURE Get_Custom_Attribute_Values 

( p_req_type_code IN VARCHAR2 

,p_pricing_type_code IN VARCHAR2 

,x_qual_ctxts_result_tbl OUT QP_ATTR_MAPPING_PUB.CONTEXTS_RESULT_TBL_TYPE 

,x_price_ctxts_result_tbl OUT QP_ATTR_MAPPING_PUB.CONTEXTS_RESULT_TBL_TYPE 

) is 

Begin 

/* Note: 

a. Assign Context Code to context_name parameter and not the name of the context. 

b. Assign Column Mapped for the attribute to attribute_name parameter and not the 

attribute name. 

c. Ensure that attribute_value is assigned to NOT NULL value, otherwise the attribute will not 

get sourced and not used by pricing engine for calculation. 

*/ 

-- The statements below help the user in turning debug on 

-- The user needs to set the oe_debug_pub.G_DIR value. 

-- This value can be found by executing the following statement 

-- select value 

-- from v$parameter 

-- where name like 'utl_file_dir%'; 

-- This might return multiple values , and any one of the values can be taken 

-- Make sure that the value of the directory specified , actually exists 



-- Sample debug message. 

-- oe_debug_pub.add ('In Get_Custom_Attribute_Values'); 



If p_req_type_code = ‘ONT’ and p_pricing_type_code in (‘L’,’H’) then 

-- Sourcing qualifier attributes. 

x_qual_ctxts_result_tbl(1).context_name := 'CUST_SOURCE_QUAL_CON'; 

x_qual_ctxts_result_tbl(1).attribute_name := 'QUALIFIER_ATTRIBUTE31'; 

x_qual_ctxts_result_tbl(1).attribute_value := '10'; 



-- Sourcing pricing attributes. 

x_price_ctxts_result_tbl(1).context_name := 'CUST_SOURCE_PRIC_CON'; 

x_price_ctxts_result_tbl(1).attribute_name := 'PRICING_ATTRIBUTE31'; 

x_price_ctxts_result_tbl(1).attribute_value:= '10'; 

end if; 

End Get_Custom_Attribute_Values; 

END QP_CUSTOM_SOURCE; 





Please note that, context_name is actually the context code and NOT the name of the context. 

Also, attribute_name is the column mapped for the attribute and NOT the attribute name. 



Troubleshooting Custom sourced attributes: 

1. Please check QP: Custom Sourced profile is set to Yes for the Attribute Manager API Build_Contexts to call QP_CUSTOM_SOURCE.Get_Custom_Attribute_Values procedure to source custom mapped attributes.

2. Please set QP: Debug profile to ‘Request Viewer On’ and reproduce the issue. Look at the Pricing Engine Request Viewer and see the custom sourced attribute is sourced correctly and the value assigned to the attribute
is matched with the setup value in the pricelist / modifier / formula setup. Please see 'Pricing Engine Request Viewer – Attributes section’ in Advanced Pricing implementation guide on how to use Pricing Engine Request Viewer for attribute sourcing issues.

3. Please check the string 'Before Calling Custom Sourcing Package' in the debug log and make sure that there is no exception/error message thrown in custom API call and check the number of custom attributes sourced.
Also, check the output of the following SQL to determine the error message thrown in the custom package: 

SELECT line || ‘/’ position POS, text from DBA_ERRORS WHERE NAME =’QP_CUSTOM_SOURCE’; 



4. Please note that the value assigned to the attribute in Get_Custom_Attribute_Values procedure should not be NULL, otherwise the attribute will not get sourced.

5. Please add debug messages in Get_Custom_Attribute_Values procedure using oe_debug_pub.add API and verify that the debug messages are printed in the debug log to diagnose the issue in the custom procedure implementation.

Advanced Pricing - How to source Pricing Attributes using QP_CUSTOM_SOURCE.Get_Custom_Attribute_Valu的更多相关文章

  1. How to Create Modifiers Using the API QP_MODIFIERS_PUB.PROCESS_MODIFIERS

    In this Document Goal   Solution   Example Scripts   Steps to verify the creation of modifier(s).   ...

  2. HOW to Use QP_PREQ_PUB.PRICE_REQUEST API to Price an Item

    In this Document Goal   Solution   References APPLIES TO: Oracle Advanced Pricing - Version 11.5.10 ...

  3. Oracle Advanced Pricing White Papers

    Oracle Order Management - Version 11.5.10.0 and later Oracle Advanced Pricing - Version 11.5.10 and ...

  4. How to: Create a C/C++ Union by Using Attributes (C#)

    [How to: Create a C/C++ Union by Using Attributes (C#)] 1.you can create what is known as a union in ...

  5. Apache OFBiz

    Apache OFBiz® Apache OFBiz offers a great deal of functionality, including: advanced e-commerce cata ...

  6. 12 Best Live Chat Software for Small Business Compared (2019) 最佳的wordpress在线聊天工具推荐插件 来帮你和潜在客户互动

    12 Best Live Chat Software for Small Business Compared (2019)     Did you know that more than 67% of ...

  7. SD从零开始11-12

    SD从零开始11 定价中的条件技术(Condition Technique in Pricing) 定价程序Pricing Procedure 所有定价中允许的条件类型都包含在定价程序中: 通过为每个 ...

  8. SAP事务码 一

    SE80 -- edit source code. SE24 -- class create or display. SFP -- created and maintained independent ...

  9. 2 Configuring SAP ERP Sales and Distribution -introduction to SAP

    First Steps in SAPWe’ll now discuss some of the basic menus, screens, and transactions that you need ...

随机推荐

  1. activiti实战系列 并行网关(parallelGateWay)

    流程图 13.2:部署流程定义+启动流程实例 13.3:查询我的个人任务 13.4:完成我的个人任务 说明: 1) 一个流程中流程实例只有1个,执行对象有多个 2)  并行网关的功能是基于进入和外出的 ...

  2. Dynamics CRM 视图显示列的拷贝—view layout replicator

    在视图设置的时候很多人会遇到这样的问题,要设置多张视图,而这多张视图可能除了筛选条件不同外其他的均相同,手动去设置是件重复的令人非常头痛的事情,如果能够拷贝那就相当完美了. 本篇即介绍视图显示列的拷贝 ...

  3. Android缩放动画

    Android缩放动画 核心方法 public void startAnimation(Animation animation) 执行动画,参数可以是各种动画的对象,Animation的多态,也可以是 ...

  4. mac OS X 从无法同步互联网时间想到的

    最近在mac OS X 巨浪 :)上执行 ntpdate time.nist.gov 失败,提示 13 Jan 19:41:53 ntpdate[1374]: the NTP socket is in ...

  5. AndroidManifest.xml中的application中的name属性

    被这个不起眼的属性折磨了一天,终于解决了. 由于项目需要,要合并两个android应用,于是拷代码,拷布局文件,拷values,所有的都搞定之后程序还是频频崩溃,一直没有找到原因,学android时间 ...

  6. linux内核cfs浅析

    linux调度器的一般原理请参阅<linux进程调度浅析>.之前的调度器cfs之前的linux调度器一般使用用户设定的静态优先级,加上对于进程交互性的判断来生成动态优先级,再根据动态优先级 ...

  7. Elcipse安装gradle插件

    参考:             http://www.gradle.org/docs/current/userguide/installation.html (1)下载Gradle 官网下载www.g ...

  8. Aandroid TV 基于Leanback支持最新MD设计的TV开发框架

    原文地址:http://blog.csdn.net/sk719887916 作者:skay 基于6.0最新的API 支持TV的框架 Android 6.0已完美支持TV开发,之前的5.0后Recycl ...

  9. linux命令指usermod(管理用户以及权限的命令)

    usermod命令:用来修改用户帐号的各项设定. 示例:usermod -a -G usergroupnewuser 或者usermod -aGusergroup newuser 语法:usermod ...

  10. 读生产环境下go语言最佳实践有感

    最近看了一篇关于go产品开发最佳实践的文章,go-in-procution.作者总结了他们在用go开发过程中的很多实际经验,我们很多其实也用到了,鉴于此,这里就简单的写写读后感,后续我也争取能将这篇文 ...