P_PriceAndQuantityVariance
Price And Quantity Variance
P_PriceAndQuantityVariance is a Consumption CDS View that provides data about "Price And Quantity Variance" in SAP S/4HANA. It reads from 1 data source (I_PurchaseOrderHistory) and exposes 21 fields with key fields PurchaseOrder, PurchaseOrderItem. It has 2 associations to related views.
Data Sources (1)
| Source | Alias | Join Type |
|---|---|---|
| I_PurchaseOrderHistory | I_PurchaseOrderHistory | from |
Parameters (2)
| Name | Type | Default |
|---|---|---|
| P_StartDate | bedat | |
| P_EndDate | bedat |
Associations (2)
| Cardinality | Target | Alias | Condition |
|---|---|---|---|
| [1..1] | I_PurchaseOrder | _PurchaseOrder | $projection.PurchaseOrder = _PurchaseOrder.PurchaseOrder |
| [1..1] | I_PurchaseOrderItem | _PurchaseOrderItem | $projection.PurchaseOrder = _PurchaseOrderItem.PurchaseOrder and $projection.PurchaseOrderItem = _PurchaseOrderItem.PurchaseOrderItem |
Annotations (7)
| Name | Value | Level | Field |
|---|---|---|---|
| AbapCatalog.sqlViewName | PMMPRCQNTYVAR | view | |
| AbapCatalog.compiler.compareFilter | true | view | |
| AbapCatalog.preserveKey | true | view | |
| AccessControl.authorizationCheck | #CHECK | view | |
| VDM.viewType | #CONSUMPTION | view | |
| VDM.private | true | view | |
| EndUserText.label | Price And Quantity Variance | view |
Fields (21)
| Key | Field | Source Table | Source Field | Description |
|---|---|---|---|---|
| KEY | PurchaseOrder | PurchaseOrder | ||
| KEY | PurchaseOrderItem | PurchaseOrderItem | ||
| PurchaseOrderQuantityUnit | _PurchaseOrderItem | PurchaseOrderQuantityUnit | ||
| NetAmount | _PurchaseOrderItem | NetAmount | ||
| OrderQuantity | _PurchaseOrderItem | OrderQuantity | ||
| PurchaseOrderTransactionType | PurchaseOrderTransactionType | |||
| PurchasingCompletenessStatus | _PurchaseOrder | PurchasingCompletenessStatus | ||
| Currency | _PurchaseOrderItem | DocumentCurrency | ||
| PurchasingDocumentCategory | _PurchaseOrderItem | PurchaseOrderCategory | ||
| PurchaseOrderDate | _PurchaseOrder | PurchaseOrderDate | ||
| Supplier | _PurchaseOrder | Supplier | ||
| PurchaseOrderType | _PurchaseOrder | PurchaseOrderType | ||
| PurchasingOrganization | _PurchaseOrder | PurchasingOrganization | ||
| PurchasingGroup | _PurchaseOrder | PurchasingGroup | ||
| Plant | _PurchaseOrderItem | Plant | ||
| Material | _PurchaseOrderItem | Material | ||
| MaterialGroup | _PurchaseOrderItem | MaterialGroup | ||
| CompanyCode | _PurchaseOrderItem | CompanyCode | ||
| NetPriceAmount | _PurchaseOrderItem | NetPriceAmount | ||
| NetPriceQuantity | _PurchaseOrderItem | NetPriceQuantity | ||
| PostingDate | PostingDate |
@AbapCatalog.sqlViewName: 'PMMPRCQNTYVAR'
@AbapCatalog.compiler.compareFilter: true
@AbapCatalog.preserveKey: true
@AccessControl.authorizationCheck: #CHECK
@VDM.viewType: #CONSUMPTION
@VDM.private: true
@EndUserText.label: 'Price And Quantity Variance'
define view P_PriceAndQuantityVariance
with parameters
P_StartDate : bedat,
P_EndDate : bedat
as select from I_PurchaseOrderHistory
association [1..1] to I_PurchaseOrder as _PurchaseOrder on $projection.PurchaseOrder = _PurchaseOrder.PurchaseOrder
association [1..1] to I_PurchaseOrderItem as _PurchaseOrderItem on $projection.PurchaseOrder = _PurchaseOrderItem.PurchaseOrder
and $projection.PurchaseOrderItem = _PurchaseOrderItem.PurchaseOrderItem
{
key PurchaseOrder,
key PurchaseOrderItem,
_PurchaseOrderItem.PurchaseOrderQuantityUnit,
_PurchaseOrderItem.NetAmount,
_PurchaseOrderItem.OrderQuantity,
PurchaseOrderTransactionType,
_PurchaseOrder.PurchasingCompletenessStatus,
_PurchaseOrderItem.DocumentCurrency as Currency,
_PurchaseOrderItem.PurchaseOrderCategory as PurchasingDocumentCategory,
_PurchaseOrder.PurchaseOrderDate,
_PurchaseOrder.Supplier,
_PurchaseOrder.PurchaseOrderType,
_PurchaseOrder.PurchasingOrganization,
_PurchaseOrder.PurchasingGroup,
_PurchaseOrderItem.Plant,
_PurchaseOrderItem.Material,
_PurchaseOrderItem.MaterialGroup,
_PurchaseOrderItem.CompanyCode,
_PurchaseOrderItem.NetPriceAmount,
_PurchaseOrderItem.NetPriceQuantity,
PostingDate,
case _PurchaseOrderItem.IsReturnsItem
when 'X' then case DebitCreditCode
when 'S' then -1 * PurchaseOrderAmount
when 'H' then PurchaseOrderAmount
else 0
end
else case DebitCreditCode
when 'S' then PurchaseOrderAmount
when 'H' then -1 * PurchaseOrderAmount
else 0
end
end as InvoiceAmountInDocCurrency,
case _PurchaseOrderItem.IsReturnsItem
when 'X' then case DebitCreditCode
when 'S' then -1 * QtyInPurchaseOrderPriceUnit
when 'H' then QtyInPurchaseOrderPriceUnit
else 0
end
else case DebitCreditCode
when 'S' then QtyInPurchaseOrderPriceUnit
when 'H' then -1 * QtyInPurchaseOrderPriceUnit
else 0
end
end as DeliveredQuantity
}
where
_PurchaseOrderItem.PurchasingDocumentDeletionCode = ''
and _PurchaseOrder.PurchasingDocumentDeletionCode = ''
and PurchaseOrderTransactionType = '2'
and _PurchaseOrder.PurchasingCompletenessStatus != 'X'
and _PurchaseOrder.ReleaseIsNotCompleted != 'X'
and(
_PurchaseOrder.Supplier <> ''
or _PurchaseOrder.Supplier is not null
) //2809288
and _PurchaseOrder.PurchaseOrderDate <= $parameters.P_EndDate
and _PurchaseOrder.PurchaseOrderDate >= $parameters.P_StartDate
and(
_PurchaseOrderItem.IsStatisticalItem = ''
or _PurchaseOrderItem.Material <> ''
)
and not(
_PurchaseOrderItem.ProductType = '2'
or(
_PurchaseOrderItem.PurchaseOrderItemCategory = '9'
or _PurchaseOrderItem.PurchaseOrderItemCategory = '1'
or _PurchaseOrderItem.PurchaseOrderItemCategory = 'A'
)
)
/*+[internal] {
"BASEINFO":
{
"FROM":
[
"I_PURCHASEORDER",
"I_PURCHASEORDERHISTORY",
"I_PURCHASEORDERITEM"
],
"ASSOCIATED":
[
"I_PURCHASEORDER",
"I_PURCHASEORDERITEM"
],
"BASE":
[],
"ANNO_REF":
[],
"SCALAR_FUNCTION":
[],
"VERSION":0,
"ANNOREF_EVALUATION_ERROR":""
}
}*/
Learn More
- What Is a CDS View in SAP S/4HANA?
- Types of CDS Views: Basic, Composite, Consumption, and Transactional
- SAP Tables vs CDS Views — Key Differences
- Understanding Data Lineage in SAP S/4HANA
- VDM (Virtual Data Model) in SAP S/4HANA Explained
- CDS View Annotations — A Complete Guide
- CDS View Field Mapping and Associations
- Understanding the SAP S/4HANA Data Model
- CDS View Extensions and Custom Fields in SAP S/4HANA
- Released APIs and Stability Contracts in SAP S/4HANA