兩種使用程式碼獲得SAP CRM product sales status的辦法

i042416發表於2020-09-22

Requirement: I would like to get Product sales status id via ABAP code. The test product id: 1467


兩種使用程式碼獲得SAP CRM product sales status的辦法


In TJ02T, we know the status id is: I1050


兩種使用程式碼獲得SAP CRM product sales status的辦法


Approach1: use function module CRM_STATUS_READ.


兩種使用程式碼獲得SAP CRM product sales status的辦法


METHOD read_prod_sales_status.
    DATA(lv_guid) = get_guid_by_id( iv_prod_id ).
    CONSTANTS: gv_salesa TYPE comm_pr_frg_rod-fragment_type
     VALUE '37D58F1B772D53A4E10000009B38FA0B'.
    DATA: lv_objnr  TYPE comm_pr_frg_rod-status_object,
          lt_status TYPE STANDARD TABLE OF jstat.
    SELECT SINGLE status_object FROM comm_pr_frg_rod INTO lv_objnr
       WHERE product_guid = lv_guid AND fragment_type = gv_salesa.
    CHECK sy-subrc = 0.
    CALL FUNCTION 'CRM_STATUS_READ'
      EXPORTING
        objnr            = lv_objnr
      TABLES
        status           = rt_status
      EXCEPTIONS
        object_not_found = 1.
  ENDMETHOD.

Output:


兩種使用程式碼獲得SAP CRM product sales status的辦法


Approach2: use BOL API

Method signature:


兩種使用程式碼獲得SAP CRM product sales status的辦法


Source code:

METHOD get_prod_sales_status_via_bol.
    DATA:
      lo_collection    TYPE REF TO if_bol_entity_col,
      lv_view_name     TYPE crmt_view_name,
      lv_query_name    TYPE crmt_ext_obj_name,
      ls_parameter     TYPE genilt_query_parameters,
      lt_sel_parameter TYPE crmt_name_value_pair_tab,
      ls_sel_parameter LIKE LINE OF lt_sel_parameter.
    lv_query_name = 'ProdAdvancedSearchProducts'.
    ls_sel_parameter = VALUE #( name = 'PRODUCT_ID' value = iv_prod_id ).
    APPEND ls_sel_parameter TO lt_sel_parameter.
    DATA(lo_result) = so_core->query(
        iv_query_name               = lv_query_name
        it_query_params = lt_sel_parameter
        iv_view_name                = lv_view_name ).
    CHECK lo_result->size( ) = 1.
    DATA(lo_product) = lo_result->get_first( ).
    DATA(lo_dc) = lo_product->get_related_entity( 'ProductDistrChain' ).
    CHECK lo_dc IS NOT INITIAL.
    DATA(lo_salesa) = lo_dc->get_related_entity( 'ProductDcSalesa' ).
    CHECK lo_salesa IS NOT INITIAL.
    RV_STATUS = lo_Salesa->get_property_as_string( 'STATUS_OBJECT' ).
  ENDMETHOD.


兩種使用程式碼獲得SAP CRM product sales status的辦法


Define a static attribute so_core and initialize it in class constructor:

method CLASS_CONSTRUCTOR.
     so_core = cl_crm_bol_core=>get_instance( ).
     so_core->load_component_set( 'PROD_ALL' ).
  endmethod.

Test result:


兩種使用程式碼獲得SAP CRM product sales status的辦法


要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

兩種使用程式碼獲得SAP CRM product sales status的辦法


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2723202/,如需轉載,請註明出處,否則將追究法律責任。

相關文章