In this Document

Goal
  Solution
  References

APPLIES TO:

Oracle Advanced Pricing - Version 11.5.10 and later

Information in this document applies to any platform.

GOAL

This note describes how the QP_PREQ_PUB.PRICE_REQUEST API can be called to obtain the Price of an item.

SOLUTION

The following is an example of how the QP_PREQ_PUB.PRICE_REQUEST API can be called to obtain the Price of an item

Examples described in this note will use the following attributes - this has been tested using data set up in a Vision instance. You will need to change data as appropriate to your environment.

NB - is important to ensure that the pricing phase on the modifier line matches the pricing event used when calling the API.

For example if the pricing phase on the modifier is -- All Line Adjustments then to apply the modifier -- p_control_rec.pricing_event :='BATCH'; or alternatively change the pricing phase to -- List Line adjustments (note that setting the phase to the value
will cause the pricing engine to update the price whenever the order line is changed and may have an impact on performance).

Pricing Attributes

1. Item priced is Inventory Item ID - 307627

Qualifier Attributes

1. Price List is Price List ID - 54824

2. Customer is Customer ID - 16071

A Modifier has been created where:

1. The Modifier is qualified at Header Level by the Customer ID - 16071

2. The Line on the modifier is qualified by pricing attribute - Inventory Item is 307627

Price List

1. For Testing purposes I have not included the Inventory Item ID -- 307627 on the price list - 54824

2. The Price List does however include an ALL_ITEMS value which sets the price to 1.23

When Calling the PRICE_REQUEST API, I have passed the following values.

1. ALL_ITEMS pricing attribute which will be used to return a price from the price list if the item has not been included on the price list. This will only return a price if the Price List has a value for ALL_ITEMS.

line_attr_rec.LINE_INDEX    := 1;

line_attr_rec.PRICING_CONTEXT    :='ITEM'; 

line_attr_rec.PRICING_ATTRIBUTE   :='PRICING_ATTRIBUTE3';

line_attr_rec.PRICING_ATTR_VALUE_FROM   :='ALL';

line_attr_rec.VALIDATED_FLAG    :='N';

p_line_attr_tbl(1)    := line_attr_rec;

2. The Inventory Item to be priced

line_attr_rec.LINE_INDEX    := 1;

line_attr_rec.PRICING_CONTEXT    :='ITEM'; 

line_attr_rec.PRICING_ATTRIBUTE   :='PRICING_ATTRIBUTE1';

line_attr_rec.PRICING_ATTR_VALUE_FROM   :='307627';                  -- INVENTORY ITEM ID

line_attr_rec.VALIDATED_FLAG    :='N';

p_line_attr_tbl(2)    := line_attr_rec;

---- Qualifier Attribute Record

3. The Price List used to price the item

qual_rec.LINE_INDEX     := 1; 

qual_rec.QUALIFIER_CONTEXT    :='MODLIST';

qual_rec.QUALIFIER_ATTRIBUTE    :='QUALIFIER_ATTRIBUTE4';

qual_rec.QUALIFIER_ATTR_VALUE_FROM   :='54824';                     -- PRICE LIST ID

qual_rec.COMPARISON_OPERATOR_CODE   := '=';

qual_rec.VALIDATED_FLAG    :='Y';

p_qual_tbl(1)     := qual_rec;

4. Customer Qualifier will be used to determine (in this test) which modifier is to be used.

qual_rec.LINE_INDEX     := 1;

qual_rec.QUALIFIER_CONTEXT    :='CUSTOMER';

qual_rec.QUALIFIER_ATTRIBUTE    :='QUALIFIER_ATTRIBUTE2';

qual_rec.QUALIFIER_ATTR_VALUE_FROM   := 16071 ;   -- CUSTOMER ID;

qual_rec.COMPARISON_OPERATOR_CODE   := '=';

qual_rec.VALIDATED_FLAG    :='Y';

p_qual_tbl(2)     := qual_rec;

The following Script will create a procedure called XX_TEST_PRICE_REQUEST ---  PRICE_REQUEST_API_EXAMPLE.sql

Do the following to run the script from a SQL*Plus session

SQL> Set Serveroutput on size 100000

SQL> Exec XX_TEST_PRICE_REQUEST

This should then return output similar to:

File : /usr/tmp/l5027518.dbg

Return Status text Routine: QP_PREQ_PUB.PRICE_REQUEST SUCCESS

Return Status  S

+---------Information Returned to Caller---------------------+

-------------Request Line Information-------------------

Line Index: 1

Unit_price: 1.23

Percent price:

Adjusted Unit Price: .615

Pricing status code: UPDATED

Pricing status text:

-----------Pricing Attributes Information-------------

Line detail Index 3

Context ITEM

Attribute PRICING_ATTRIBUTE1

Value 307627

Status Code

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

Line detail Index 2

Context ITEM

Attribute PRICING_ATTRIBUTE3

Value ALL

Status Code

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

-----------Qualifier Attributes Information-------------

Line Detail Index 3

Context CUSTOMER

Attribute QUALIFIER_ATTRIBUTE2

Value 16071

Status Code N

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

------------Price List/Discount Information------------

Line Index: 1

Line Detail Index: 2

Line Detail Type:NULL

List Header Id: 54824

List Line Id: 189859

List Line Type Code: PLL

Adjustment Amount : 1.23

Line Quantity :

Operand Calculation Code: UNIT_PRICE

Operand value: 1.23

Automatic Flag: Y

Override Flag:

status_code: N

status text: INSERTED IN L_LIST_CUR

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

Line Index: 1

Line Detail Index: 3

Line Detail Type:NULL

List Header Id: 191260

List Line Id: 221749

List Line Type Code: DIS

Adjustment Amount : -.615

Line Quantity :

Operand Calculation Code: %

Operand value: 50

Automatic Flag: Y

Override Flag: N

status_code: N

status text: PRODUCT_QUALIFIER_ONLY

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

--------------Related Lines Information for Price Breaks/Service

Items---------------

PL/SQL procedure successfully completed.

The Important Elements shown here are:

1. /usr/tmp/l5027518.dbg     --  additional debug information is located
in this file

The following information is shown in the debug file:

2. Request Line Information     --  Shows the price returned by the API

3. Pricing Attributes Information --  Shows Pricing Attributes used to determine the price -- Note only the attributes used will be shown

4. Qualifier Attributes Information --  Shows Qualifier Attributes used to determine the price -- Note only the attributes used will be shown

5. Price List/Discount Information --  Shows the price list chosen as well as the modifiers which have been used to price the item.

The following file is a LIST_LINE_DETAIL diagnostics report for the modifier (list line id - 221749). This shows the modifier details including pricing and qualifier attributes.

Modifier_definition

Note: 163913.1 - Debugging Advanced Pricing Modifier and Price List Lines (qp_list_line_detail.sql)

An alternative method of obtaining this report is to run -- Diagnostics: List Line Details -- concurrent process from a Pricing Manager Responsibility.

Additional reference: Note 412545.1 - Pricing Engine: How to simulate the Price Order Function using an API

Still Have Questions? 

To discuss this information further with Oracle experts and industry peers, we encourage you to review, join or start a discussion in the My
Oracle Advanced Pricing Community
.


REFERENCES

NOTE:412545.1 - How to Simulate the Price Order or Price Line Function using API QP_PREQ_PUB.PRICE_REQUEST Includes Example Scripts



NOTE:1448751.1 - Qp_preq_pub.Price_request Is Not Showing a Discount Defined at Group of Lines Level

NOTE:163913.1 - Diagnostic Report for Advanced Pricing Modifier and Price List Lines (qp_list_line_detail.sql)

文档详细信息

 

 
  类型:
  状态:
  上次主更新:
  上次更新:
 
  HOWTO
  PUBLISHED
  2014-11-4
  2014-11-4

     
 

相关产品

 
Oracle Advanced Pricing
     

 
 

附件

   
 

HOW to Use QP_PREQ_PUB.PRICE_REQUEST API to Price an Item的更多相关文章

  1. Sample Code for Qp_preq_pub.Price_request Api to Simulate an Ask for Promotion Modifier

    DECLARE p_line_tbl QP_PREQ_GRP.LINE_TBL_TYPE; p_qual_tbl QP_PREQ_GRP.QUAL_TBL_TYPE; p_line_attr_tbl ...

  2. How to Simulate the Price Order or Price Line Function using API QP_PREQ_PUB.PRICE_REQUEST Includes

    How to Simulate the Price Order or Price Line Function using API QP_PREQ_PUB.PRICE_REQUEST Includes ...

  3. 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).   ...

  4. 集成架构:对比 Web API 与面向服务的架构和企业应用程序集成(转)

    http://kb.cnblogs.com/page/521644/ 摘要:总体上讲,SOA 和 Web API 似乎解决的是同一个问题:以实时的.可重用的方式公开业务功能.本教程将分析这些举措有何不 ...

  5. (转)集成架构:对比 Web API 与面向服务的架构和企业应用程序集成

    摘要:总体上讲,SOA 和 Web API 似乎解决的是同一个问题:以实时的.可重用的方式公开业务功能.本教程将分析这些举措有何不同,以及如何将它们融入到一个不断演变的集成架构中.文中还将讨论 API ...

  6. 购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(2)--前端,以及前后端Session

    原文:购物车Demo,前端使用AngularJS,后端使用ASP.NET Web API(2)--前端,以及前后端Session chsakell分享了前端使用AngularJS,后端使用ASP.NE ...

  7. 【netcore基础】.NET Core使用EPPlus实现MVC API里的Excel导出功能 配置中文表头

    EPPlus 用来操作excel非常方便,不用依赖微软的office包,所以推荐使用. 下面是具体步骤和代码 首先用nuget安装 EPPlus.Core 我装的版本是 1.5.4 然后就可以用 Ex ...

  8. 使用 ASP.NET Core MVC 创建 Web API(六)

    使用 ASP.NET Core MVC 创建 Web API 使用 ASP.NET Core MVC 创建 Web API(一) 使用 ASP.NET Core MVC 创建 Web API(二) 使 ...

  9. ebay API属性

    Ebay Trading API整理 纠纷相关 AddDispute:创建一个未支付纠纷 或 取消 a single line item order AddDisputeResponse:回复/关闭d ...

随机推荐

  1. ROS探索总结(十九)——如何配置机器人的导航功能

    1.概述 ROS的二维导航功能包,简单来说,就是根据输入的里程计等传感器的信息流和机器人的全局位置,通过导航算法,计算得出安全可靠的机器人速度控制指令.但是,如何在特定的机器人上实现导航功能包的功能, ...

  2. React Native实现一个自定义模块

    概述 在 前期介绍React Native 项目结构的时候,我们讲解过React的项目组成,其中说过 node_modules 文件夹,这是一个存放 node 模块的地方.我们知道React是用npm ...

  3. ActiveMQ入门示例

    1.ActiveMQ下载地址 http://activemq.apache.org/download.html 2.ActiveMQ安装,下载解压之后如下目录

  4. itoo-快捷部署脚本--提高部署开发效率

     本次是第一次使用批处理文件来作为批量操作的工具,代替了人工的手动的复制,粘贴的方式,使用脚本实现了项目的启动.自动化部署,打开项目根目录.等等,提高了开发和调试的效率. 说明: 当前版本:1.0 ...

  5. 04_关于元数据,ResultSetMetaData对象以及API方法介绍

     ResultSetMetaData对象 元数据,可以理解为数据的数据 Jdbc中的元数据是指数据库.表.列的定义信息. ResultSetMetaData对象表示结果集ResultSet对象的元 ...

  6. 1.2、Android Studio为新设备创建一个模块

    模块为你的应用的源码.资源文件和app level设置(比如AndroidManifest.xml)提供了一个容器.每个模块可以独立的构建.测试和调试. 通过使用模块,Android Studio可以 ...

  7. [ExtJS5学习笔记]第六节 Extjs的类系统Class System命名规则及定义和调试

    本文地址: http://blog.csdn.net/sushengmiyan/article/details/38479079 本文作者:sushengmiyan ----------------- ...

  8. GDAL使用插件方式编译HDF4、HDF5以及NetCDF的bug修改

    GDAL库中提供了很方便的插件机制来扩展支持的数据格式,比如HDF4.HDF5.NetCDF.FileGDB.Postgre.Oralce等等.都可以通过插件的方式来使得GDAL支持相应的格式.最近将 ...

  9. Xcode中为何要为设置bundle和App分别设置两份一样的图片资源

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我们知道在App设置的bundle中有时也会用到图片资源,而在 ...

  10. 07 ProgressDialog

    <span style="font-size:18px;">package com.fmy.example1; import android.app.Activity; ...