I_ProductGroupHierarchyNode

DDL: I_PRODUCTGROUPHIERARCHYNODE Type: view_entity BASIC Package: FINS_FIS_FICO

Product Group Hierarchy Node

I_ProductGroupHierarchyNode is a Basic CDS View that provides data about "Product Group Hierarchy Node" in SAP S/4HANA. It reads from 1 data source (hrrp_node_n) and exposes 13 fields with key fields ProductGroupHierarchy, HierarchyNode, ValidityEndDate. It has 3 associations to related views. Part of development package FINS_FIS_FICO.

Data Sources (1)

SourceAliasJoin Type
hrrp_node_n hrrp_node_n from

Associations (3)

CardinalityTargetAliasCondition
[1..1] I_ProductGroupHierarchy _Hierarchy $projection.ProductGroupHierarchy = _Hierarchy.ProductGroupHierarchy and $projection.ValidityEndDate = _Hierarchy.ValidityEndDate
[0..1] I_ProductGroup_2 _ProductGroup $projection.ProductGroup = _ProductGroup.ProductGroup
[0..*] I_ProductGroupHierNodeText _Text $projection.ProductGroupHierarchy = _Text.ProductGroupHierarchy and $projection.HierarchyNode = _Text.HierarchyNode and $projection.ProductGroup = ''

Annotations (12)

NameValueLevelField
AccessControl.authorizationCheck #MANDATORY view
EndUserText.label Product Group Hierarchy Node view
Metadata.ignorePropagatedAnnotations true view
ObjectModel.usageType.dataClass #MASTER view
ObjectModel.usageType.serviceQuality #A view
ObjectModel.usageType.sizeCategory #L view
ObjectModel.dataCategory #HIERARCHY view
VDM.viewType #BASIC view
Analytics.dataExtraction.enabled true view
ObjectModel.representativeKey HierarchyNode view
ObjectModel.sapObjectNodeType.name ProductGroupHierarchyNode view
ObjectModel.modelingPattern #ANALYTICAL_PARENT_CHILD_HIERARCHY_NODE view

Fields (13)

KeyFieldSource TableSource FieldDescription
KEY ProductGroupHierarchy
KEY HierarchyNode hrrp_node_n hrynode
KEY ValidityEndDate
ValidityStartDate
ParentNode hrrp_node_n parnode
ProductGroup hrrp_node_n matkl
HierarchyNodeSequence hrrp_node_n hryseqnbr
HierarchyNodeLevel hrrp_node_n hrylevel
NodeType hrrp_node_n nodetype
HierarchyNodeVal hrrp_node_n nodevalue
_Text _Text
_ProductGroup _ProductGroup
_Hierarchy _Hierarchy
@AbapCatalog.viewEnhancementCategory: [#NONE]
@AccessControl.authorizationCheck: #MANDATORY
@EndUserText.label: 'Product Group Hierarchy Node'
@Metadata.ignorePropagatedAnnotations: true
@ObjectModel: {usageType: {
  dataClass: #MASTER,
  serviceQuality: #A,
  sizeCategory: #L},
  dataCategory: #HIERARCHY
}
@VDM.viewType: #BASIC
@Hierarchy.parentChild:
[{ recurse:          {   parent: ['ParentNode'],   child:  ['HierarchyNode']  },
  siblingsOrder:    [{   by: 'HierarchyNodeSequence' }],
  directory:        '_Hierarchy'
  }]
@Analytics.dataExtraction.enabled: true
@ObjectModel.representativeKey: 'HierarchyNode'
@ObjectModel.sapObjectNodeType.name:'ProductGroupHierarchyNode'
@ObjectModel.modelingPattern: #ANALYTICAL_PARENT_CHILD_HIERARCHY_NODE
@ObjectModel.supportedCapabilities: [ #CDS_MODELING_DATA_SOURCE, #CDS_MODELING_ASSOCIATION_TARGET,#ANALYTICAL_PARENT_CHILD_HIERARCHY_NODE , #EXTRACTION_DATA_SOURCE ]

define view entity I_ProductGroupHierarchyNode
  as select from hrrp_node_n
  association [1..1] to I_ProductGroupHierarchy    as _Hierarchy    on  $projection.ProductGroupHierarchy = _Hierarchy.ProductGroupHierarchy
                                                                    and $projection.ValidityEndDate        = _Hierarchy.ValidityEndDate
  association [0..1] to I_ProductGroup_2           as _ProductGroup on  $projection.ProductGroup           = _ProductGroup.ProductGroup
  association [0..*] to I_ProductGroupHierNodeText as _Text         on  $projection.ProductGroupHierarchy = _Text.ProductGroupHierarchy
                                                                    and $projection.HierarchyNode          = _Text.HierarchyNode
                                                                    and $projection.ProductGroup           = '' // just to show that this association is only to be followed if BillingDocumentType is blank

{
      @Consumption.filter: {mandatory : true, selectionType : #SINGLE, multipleSelections : false }
      @ObjectModel.foreignKey.association: '_Hierarchy'
  key cast(hrrp_node_n.hryid as fis_hryid_productgroup preserving type ) as ProductGroupHierarchy,
      @ObjectModel.text.association: '_Text'
  key hrrp_node_n.hrynode                                                as HierarchyNode,
      @Semantics.businessDate.to: true
      @Consumption.filter: {mandatory : true, selectionType : #SINGLE, multipleSelections : false }
  key cast(hrrp_node_n.hryvalto as fis_datbi preserving type )           as ValidityEndDate,
      @Semantics.businessDate.from: true
      cast(hrrp_node_n.hryvalfrom as fis_datab preserving type )         as ValidityStartDate,
      hrrp_node_n.parnode                                                as ParentNode,

      @ObjectModel.foreignKey.association: '_ProductGroup'
      hrrp_node_n.matkl                                                  as ProductGroup,
      hrrp_node_n.hryseqnbr                                              as HierarchyNodeSequence,
      hrrp_node_n.hrylevel                                               as HierarchyNodeLevel,
      hrrp_node_n.nodetype                                               as NodeType,
      hrrp_node_n.nodevalue                                              as HierarchyNodeVal,

      _Text,
      _ProductGroup,
      _Hierarchy
}
where
      hrrp_node_n.nodetype <> 'D'
  and hrrp_node_n.hrytyp   =  'U509'