zoukankan      html  css  js  c++  java
  • 如何创建自己的SAP CRM产品主数据search scenario

    Created by Jerry Wang, last modified on Oct 03, 2016

    Technically it is possible to create your own search scenario, filter class and search tool, and put your custom search logic there. Then write another report to trigger search implemented by your own search scenario:

    (1) Create your filter class with interface IF_COM_PRSEARCHFILTER.

    Put your own filter logic in method FILTER. It will be called by your own search tool.
    Define which search criteria will be relevant for your filter. In my example since I need to re-implement search by object description, so I make short text set type as relevant criteria.

    (2) Create your own search tool with interface IF_COM_PRSEARCHTOOL.

    Implement method RELEVANT_CRITERIA which has the same logic as your own filter class.

    Implement method GETLIST_ACTIVE. Put your optimized solution in this method.

    (3) Create your search scenario class with super class CL_COM_PRSEARCHSCENARIO_BASE.
    Redefine DETERMINE_STANDARD_TOOL.
    Just specify your own search tool and filter class in this method.

      CREATE OBJECT lr_tool TYPE ZCL_NEW_SEARCH_TOOL_AFTER_OPT.
      ei_tool = lr_tool.
      CREATE OBJECT lr_filter TYPE ZCL_NEW_FILTER_AFTER_OPT.
      INSERT lr_filter INTO TABLE et_filter.
    

    (4) [Optional] integrate your own search in PREPARE_DB_RANGE_SEARCH ( standard code change necessary )

    (5) Since currently we do not need to integrate the new search via end-to-end way, we simply write a report to trigger search which will use our own search:
    This FM will not be used by UI search, so when you are comparing your search performance with standard search, please also trigger standard search via this report, too.

    ls_option-frgtype_id = 'COMM_PR_SHTEXT'.
    ls_option-attribute  = 'SHORT_TEXT'.
    ls_option-sign       = 'I'.
    ls_option-option     = 'EQ'.
    ls_option-low        = 'object mass created of 200124'.
    ls_option-high       = space.
    INSERT ls_option INTO TABLE lt_option.
    CALL FUNCTION 'COM_PRODUCT_GETLIST_API'
      EXPORTING
        it_gen_sel_options = lt_option
        iv_scenario        = 'ZCL_NEW_SCENARIO_AFTER_OPT'
      IMPORTING
        et_product         = lt_product
        et_bapireturn      = lt_return
    

    要获取更多Jerry的原创文章,请关注公众号"汪子熙":

  • 相关阅读:
    Promises-小程序购物车结算
    微信小程序支付
    微信企业付款到零钱
    Ubuntu16 远程连接MySQL
    MySQL数据库中文变问号
    Ubuntu开启ApacheRewrite功能
    大数据2018:云存储已在客观层面扮演数据湖角色
    地平线发布兼具本地端抓拍与识别功能的嵌入式AI摄像机
    肥皂遇上黑科技!异味统统都走开!
    LG新专利或用于移动VR,可通过外部旋钮调节显示屏与透镜
  • 原文地址:https://www.cnblogs.com/sap-jerry/p/13218231.html
Copyright © 2011-2022 走看看