SAP CDS+AMDP获取订单状态文本(替代函数STATUS_TEXT_EDIT)

2024-01-25 14:36

本文主要是介绍SAP CDS+AMDP获取订单状态文本(替代函数STATUS_TEXT_EDIT),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:

客户反映某本报表运行效率极慢,需要进行优化,简单看了代码并且使用SAT分析后,定位了两个主要的问题,最主要的问题是合计数量的时候在LOOP循环中使用了SELECT SUM(*) FROM internal_table,而且还有很多个,导致当LOOP的本地内表条目比较大的时候,效率将会受到非常大的影响;其次是在循环中调用函数STATUS_TEXT_EDIT来获取订单文本,这个其实影响不算很大,但为了最大化提升效率,针对这点也做了优化。

优化前:time out dump。

优化后:10秒运行完成。


问题点1:

最大的元凶就是下面这段代码,LOOP中多个聚合函数导致随着数据量的增加,效率会异常低下。

解决方式:

sort table + collect 


问题点2:

循环中调用函数获取订单状态文本,对性能影响较小,不过本着能优则优的心态,顺手也对其进行了优化。

解决方式: 

table function + cds view 

1.首先定义table function:ZPRPP_ORDER_STATUS_TF

@ClientDependent: false
@AccessControl.authorizationCheck: #CHECK
@EndUserText.label: 'Table function for get PP order status'
define table function ZPRPP_ORDER_STATUS_TF
returns
{objnr          :j_objnr;status_profile :j_stsma;@EndUserText.label: 'System status'system_status  :char60;
}
implemented by methodzprcl_st_text=>get_status_text;

2.然后创建实现类: zprcl_st_text

CLASS zprcl_st_text DEFINITIONPUBLICFINALCREATE PUBLIC .PUBLIC SECTION.INTERFACES if_amdp_marker_hdb.CLASS-METHODS get_status_text FOR TABLE FUNCTION zprpp_order_status_tf.PROTECTED SECTION.PRIVATE SECTION.
ENDCLASS.CLASS zprcl_st_text IMPLEMENTATION.METHOD get_status_text BY DATABASE FUNCTIONFOR HDBLANGUAGE SQLSCRIPTOPTIONS READ-ONLYUSING jest jsto tj02t tj02 tj04.declare lv_99 "$ABAP.type( numc2 )";lv_99 = 99;gt_status = select distincta.objnr,b.stsma as status_profile,d.txt04 as system_status,E.nodis as no_display,CASEwhen f.linep is not null or f.linep <> 00 thenf.linepelselv_99end as position,CASEwhen f.statp is not null or f.statp <> 00 thenf.statpelselv_99end as priorityfrom jest as ainner join jsto as bon b.objnr = a.objnrleft outer join tj02t as don d.istat = a.statinner join tj02 as e on e.istat = a.statleft outer join tj04 as fon f.obtyp = b.obtypand f.istat = a.statwhere a.inact <> 'X'and e.nodis <> 'X'and a.mandt = session_context('CLIENT')and b.mandt = session_context('CLIENT')and d.spras = session_context('LOCALE_SAP')order by POSITION desc,priority desc,system_status desc;RETURN SELECT objnr,status_profile,STRING_AGG( system_status, char( 32 ) ORDER BY position asc, priority asc, system_status asc ) as system_statusFROM :gt_statusGROUP BY objnr, status_profile;ENDMETHOD.
ENDCLASS.

3.最后创建cds view:

@AbapCatalog.sqlViewName: 'ZPRPPORDSTTXT'
@AbapCatalog.compiler.compareFilter: true
@AbapCatalog.preserveKey: true
@AccessControl.authorizationCheck: #CHECK
@EndUserText.label: 'CDS View for get PP order status text'
define view ZPRPP_ORDER_STATUS_Vas select from ZPRPP_ORDER_STATUS_TF
{key objnr,status_profile,@EndUserText.label: 'System status'cast(system_status as abap.char(60)) as system_status
}

 4.在循环外直接根据AFKO-OBJNR关联该cds对应的sql view,一条sql即可获取订单状态。


注意点:

AMDP用的并不是特别熟练,有几个小的知识点也记录一下,方便我后续查找吧。

变量声明

        declare lv_99 "$ABAP.type( numc2 )";

系统变量:

  • session_context('CLIENT')  等同于 SY-MANDT
  • session_context('APPLICATIONUSER')  等同于 SY-UNAME
  • session_context('LOCALE_SAP') 等同于 SY-LANGU
  • session_context('SAP_SYSTEM_DATE') 等同于 SY-DATUM

空格:

        char( 32 )  代表空格

空格问题参考链接:The ABAPVARCHARMODE: Blanks and Empty Strings in ABAP and SQLScript (brandeis.de)

排序拼接: 

        基于函数STATUS_TEXT_EDIT的输出规则,在行转列拼接时要按照指定的顺序拼接展示,在string_agg方法中使用order by即可指定拼接顺序,asc为升序,desc为降序。


总结:

尽可能的避免在循环中多次出现数据库操作语句,程序性能优化是一个慢慢积累的过程,能跑出来结果永远是最低标准。

以上。

这篇关于SAP CDS+AMDP获取订单状态文本(替代函数STATUS_TEXT_EDIT)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/643567

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

python 常见数学公式函数使用详解(最新推荐)

《python常见数学公式函数使用详解(最新推荐)》文章介绍了Python的数学计算工具,涵盖内置函数、math/cmath标准库及numpy/scipy/sympy第三方库,支持从基础算术到复杂数... 目录python 数学公式与函数大全1. 基本数学运算1.1 算术运算1.2 分数与小数2. 数学函数