出于方便的目的,这边将BU_GROUP,SALE_ORG加到了BP搜索里面,因为CRM项目推广了很多国家,每个国家一个SALE ORG,而标准的BP HEADER ADV SEARCH里竟然没有BU_GROUP。。。。所以这边就把这两个字段加到搜索条件里了。

至于怎么加进去的就不说了,已经经历了好几代开发的手了。。。

但是效率一直是用户所追求的,而标准的BP搜索,都是很挫的那种,先做查询优先级,然后根据优先得出的PARTNER KEY再去关联其他信息做过滤。。。

可能是查询条件太多,牵涉的表太多,所以系统才用这种办法吧,但是每次500条,然后过滤,然后再500,再过滤,直到补齐查询的MAX HIT

以上是查询的逻辑,不多说,下面来说说怎么优化性的将这两个字段加入到主查询中(因为这两个字段是最常用的,也最可能单独使用的,所以不加到查询中,只过滤会很慢)

1.复制标准的查询类:CL_BUPA_IL_HEADER_SEARCH->ZL_BUPA_IL_HEADER_SEARCH

此类中的GET_DYNAMIC_QUERY_RESULT会做个优先排序:checked_search_available

然后在GET_RESULT_TABLE_CHECKED中动态拼接查询方法:CALL METHOD me->(lv_method_name)

前面基本不动,因为要把这两个查询条件放到主查询中,所以在上面的lv_method_name 等于‘SEARCH_BP_GENERAL’的时候,增加处理逻辑

增加SEARCH接构:ls_bp_gen_search01 TYPE Zcrmt_bupa_il_bp_gen_search,(额外DATA定义的)

selection处理前,添加parameters:

"add attr to gen field by ly 20170525
IF ME->GV_CONDITION = 'X'.
APPEND 'ZSALES_ORG' to gt_bp_gen_attributes.
APPEND 'ZBP_GROUP' to gt_bp_gen_attributes.
ENDIF.

处理结束后删除:

"delete add attr gen field append up by ly 20170525
IF ME->GV_CONDITION = 'X'.
delete gt_bp_gen_attributes WHERE table_line = 'ZSALES_ORG'.
delete gt_bp_gen_attributes WHERE table_line = 'ZBP_GROUP'.
ENDIF.

调用查询方法增强:

* get partner package matching the but000 criteria:
IF ME->GV_CONDITION = ''."BP查询开关,未开启则走原始逻辑 add by ly 20170526
CALL METHOD cl_bupa_il_search_service=>search_by_bp_general
EXPORTING
is_control = is_control
is_bp_gen_search = ls_bp_gen_search
iv_max_hit = lv_max_hits
it_selection_parameters = lt_bp_gen_params
iv_last_selected_partner = lv_last_selected_partner
CHANGING
ct_partner_keys = lt_partner_keys
ct_return = ct_return.
"CHANGE FROM cl_bupa_il_search_service=>search_by_bp_general TO Zcl_bupa_il_search_service=>search_by_bp_general
"by ly 20170525
ELSE."BP查询开关,未开启则走原始逻辑开启则走新逻辑 add by ly 20170526
CALL METHOD Zcl_bupa_il_search_service=>zsearch_by_bp_general
EXPORTING
is_control = is_control
is_bp_gen_search = ls_bp_gen_search01
iv_max_hit = lv_max_hits
it_selection_parameters = lt_bp_gen_params
iv_last_selected_partner = lv_last_selected_partner
GV_CONDITION = ME->GV_CONDITION
CHANGING
ct_partner_keys = lt_partner_keys
ct_return = ct_return.
ENDIF.

复制cl_bupa_il_search_service的search_by_bp_general到zcl_bupa_il_search_service为:ZSEARCH_BP_GENERAL

而原本的zsearch_by_bp_general改为调用ZSEARCH_BP_GENERAL

METHOD zsearch_by_bp_general.
"CHANGE TO BY LY 20170525
CALL METHOD zcl_bupa_il_search_service=>ZSEARCH_BP_GENERAL"search_by_bp_general
EXPORTING
is_control = is_control
is_bp_gen_search = is_bp_gen_search
iv_max_hit = iv_max_hit
it_selection_parameters = it_selection_parameters
iv_last_selected_partner = iv_last_selected_partner
GV_CONDITION = GV_CONDITION
CHANGING
ct_partner_keys = ct_partner_keys
ct_return = ct_return.
ENDMETHOD.

拼接动态查询时添加:(append_where_cond_to_select原样从cl_bupa_il_search_service中复制过来,包括对应用到的结构)

  "add where  cluse by ly 20170525  BP查询开关开启 添加查询条件    BEGIN
IF is_bp_gen_search-ZBP_GROUP IS NOT INITIAL AND GV_CONDITION = 'X'.
CALL METHOD cl_bupa_il_search_service=>map_attribute_to_range_tab
EXPORTING
iv_attribute_name = 'ZBP_GROUP'
it_selection_parameters = it_selection_parameters
IMPORTING
et_range_tab = lt_group.
IF lt_group IS NOT INITIAL.
append_where_cond_to_select( EXPORTING iv_where_line = 'BU_GROUP IN lt_group '
CHANGING ct_where_pattern = lt_where_pattern ). "#EC NOTEXT
ENDIF.
ENDIF. IF is_bp_gen_search-ZSALES_ORG IS NOT INITIAL AND GV_CONDITION = 'X'.
CALL METHOD cl_bupa_il_search_service=>map_attribute_to_range_tab
EXPORTING
iv_attribute_name = 'ZSALES_ORG'
it_selection_parameters = it_selection_parameters
IMPORTING
et_range_tab = lt_SALES_ORG.
IF lt_SALES_ORG IS NOT INITIAL.
append_where_cond_to_select( EXPORTING iv_where_line = 'SALES_ORG IN lt_SALES_ORG '
CHANGING ct_where_pattern = lt_where_pattern ). "#EC NOTEXT
ENDIF.
ENDIF.
"add where cluse by ly 20170525 BP查询开关开启 添加查询条件 end

修改查询的对象,从BUT000到新的视图‘ZCRMV_BP_SEARCH’(此视图后面说明)

* DATA:  lv_from_clause TYPE string VALUE 'BUT000 '.
DATA: lv_from_clause TYPE string VALUE 'ZCRMV_BP_SEARCH '."CHANGE BY LY 20170525
IF ( is_bp_gen_search-ZSALES_ORG IS INITIAL AND is_bp_gen_search-ZBP_GROUP IS INITIAL ) or is_control-employees = 'X'."add by ly 20170525
lv_from_clause = 'BUT000'.
ENDIF. IF GV_CONDITION = ''."BP查询开关,如果未开启,则走原始逻辑
lv_from_clause = 'BUT000'.
ENDIF.

另外,在查询后的数据过滤,也做个指向更改:FILTER_BY_SEARCH_CRITERIA

DATA ls_search_criteria01  TYPE ZHSCRMT_BUPA_IL_HEADER_SEARCH."change by ly 20170525
DATA ls_search_criteria TYPE crmt_bupa_il_header_search.
* search by general but000 data
IF ls_search_criteria01-bpgeneral IS NOT INITIAL.
IF ME->GV_CONDITION = ''.
CALL METHOD cl_bupa_il_search_service=>search_by_bp_general
EXPORTING
is_control = ls_control
is_bp_gen_search = ls_search_criteria-bpgeneral
it_selection_parameters = lt_selection_parameters
CHANGING
ct_partner_keys = ct_partner_keys
ct_return = lt_return.
APPEND LINES OF lt_return TO ct_return .
IF ct_partner_keys IS INITIAL.
* criteria given, but no result found
RETURN.
ENDIF.
ELSE.
"change by ly 20170525
CALL METHOD zcl_bupa_il_search_service=>ZSEARCH_BP_GENERAL
EXPORTING
is_control = ls_control
is_bp_gen_search = ls_search_criteria01-bpgeneral
it_selection_parameters = lt_selection_parameters
GV_CONDITION = ME->GV_CONDITION
CHANGING
ct_partner_keys = ct_partner_keys
ct_return = lt_return.
APPEND LINES OF lt_return TO ct_return .
IF ct_partner_keys IS INITIAL.
* criteria given, but no result found
RETURN.
ENDIF.
ENDIF. ENDIF.

将GENERAL中的查询字段都添加进这个视图,后面查询时则自动匹配,省去了过滤的时间和效率。

优化效率说明:将查询能卡死或者超过30分钟的,优化到2-3秒,一是因为数据存储和查询条件的无序,二是省略了多次查询BUT000大数据量的表

BUT000数据量:60W,里面的数据是按照推广的顺序依次创建的,那么后面推广的国家的数据会存的最'深'。

只用BU_GROUP和SALE_ORG查询时,会从BUT000中一次500条排序取,然后根据GROUP和SALE过滤,这样直到取到有效的数据需要60W/500 = 1200次,每次查询后还要查询一到两次BUT000,每次大概耗时1-2秒。

优化后从新建的视图中取数,在只用GROUP和SALE时,只取一次,全部满足,不在额外查询BUT000.。。。

影响分析:原始的增强查询是有其他查询条件时先查其他,在用GENERAL过滤,然后再过滤GROUP和SALE

处理后,用配置可配置是否走这个增强,原始的查询走向不变,在特定情况会从新视图中查询和过滤,无二次过滤。

在普通情况依然走原始逻辑,特殊情况走新视图。

^_^没怎么好好整理,有点乱

CRM BP SEARCH 优化的更多相关文章

  1. CRM BP函数

    REPORT ZCRM_BP_TEST. """""""""""""& ...

  2. CRM ORDER SEARCH增强查询条件(已有字段)

    ORDER_H表增强的两个字段,很早了,非AET,非EEWB,所以也加不到标准的搜索界面. GENIL_MODEL_BROWSER找到对应的查询和结果结构,append进字段:ZZZBRAND. 然后 ...

  3. SQLite3源程序分析之查询处理及优化

    前言 查询处理及优化是关系数据库得以流行的根本原因,也是关系数据库系统最核心的技术之一.SQLite的查询处理模块很精致,而且很容易移植到不支持SQL的存储引擎(Berkeley DB最新的版本已经将 ...

  4. Dynamics CRM 2016 Web API 消息列表

    Function Name Description CalculateTotalTimeIncident Function Calculates the total time, in minutes, ...

  5. 【翻译】借助 NeoCPU 在 CPU 上进行 CNN 模型推理优化

    本文翻译自 Yizhi Liu, Yao Wang, Ruofei Yu.. 的  "Optimizing CNN Model Inference on CPUs" 原文链接: h ...

  6. 如何通过在线CRM提升企业竞争力?

    随着信息技术的快速发展,在线CRM系统也得到了更加广泛的应用,已经在企业中逐渐开始普及.CRM系统对于优化企业流程有着十分重要的意义,它能够让企业的经营管理更加敏捷,并且可以快速地响应企业的业务流程. ...

  7. 不同规模的企业对CRM的需求是否相同?

    CRM客户管理系统在我们的认知中往往是中大型企业的选择.如今,越来越多中小规模企业开始使用CRM系统.CRM的功能随着发展变得越来越实用,可以满足不同行业不同业务规模的企业的需求.同时,CRM功能类型 ...

  8. CRM的未来发展前景有哪些?

    随着时代的发展,近年来越来越多的国内中小企业开始采用CRM客户关系管理系统,CRM从此不再是大企业的专利,也开始让中小企业得以不断成长.国内CRM行业的发展越来越快, 它的前景是什么?今天小Z就来给大 ...

  9. CRM系统实施中如何避免“踩雷”

    CRM系统实施后,效果没有达到预期是很多企业出现的情况.而最主要的原因就是在实施之前没有足够的思考和相应的计划.那么,企业应如何避免CRM系统实施时"踩雷"?这里有几条建议希望可以 ...

随机推荐

  1. facebook api之Ads Insights API

    The Ads Insights API provides API access for reporting and analytics purposes. When exclusively usin ...

  2. CAS 单点登录 移动端获取TGT、ST 已经移动端登录页面不进行跳转的设置

    一.设置移动客户端验证ST通过后,页面不进行302重定向跳转 修改web.xml <!--**************************************************** ...

  3. PHP 常见的数据加密技术

    单项散列加密技术(不可逆的加密) 把任意长的输入字符串变化为固定长的输出串的一种函数 MD5 string md5 ( string $str [, bool $raw_output = false ...

  4. 基因组与Python --PyVCF 好用的vcf文件处理器

    vcf文件的全称是variant call file,即突变识别文件,它是基因组工作流程中产生的一种文件,保存的是基因组上的突变信息.通过对vcf文件进行分析,可以得到个体的变异信息.嗯,总之,这是很 ...

  5. react native 第三方组件react-native-swiper 轮播组件

    github地址:https://github.com/leecade/react-native-swiper 使用方法:安装:npm i react-native-swiper –save 查看模块 ...

  6. RxJava + Retrofit

    一.添加依赖 compile 'io.reactivex:rxandroid:1.2.0' compile 'io.reactivex:rxjava:1.1.5' compile 'com.googl ...

  7. 牛客国庆集训派对Day3 A Knight

    Knight 思路: bfs打表找规律 如下图 代码: #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize(4) ...

  8. echart 注意事项-初始化和销毁

    net5x 博客园 首页 新随笔 联系 管理 订阅 随笔- 21  文章- 186  评论- 4  ECharts图表初级入门(三):ECharts对象的数据实例化方法汇总以及注意事项   [摘要]: ...

  9. 为 昂达 v891 安装上了 remix OS 了

    起因: 默认的ROM自带一堆垃圾app,最主要的是没有root , 所以卸载不了. 然后试了 Root大师 , 刷机精灵 之类的软件. 我 CTMD , 简直比出厂ROM 还流氓, 不断的强制安装各种 ...

  10. 在Spring Boot中使用 @ConfigurationProperties 注解, @EnableConfigurationProperties

    但 Spring Boot 提供了另一种方式 ,能够根据类型校验和管理application中的bean. 这里会介绍如何使用@ConfigurationProperties.继续使用mail做例子. ...