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

相关文章

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

Python Counter 函数使用案例

《PythonCounter函数使用案例》Counter是collections模块中的一个类,专门用于对可迭代对象中的元素进行计数,接下来通过本文给大家介绍PythonCounter函数使用案例... 目录一、Counter函数概述二、基本使用案例(一)列表元素计数(二)字符串字符计数(三)元组计数三、C

Python文本相似度计算的方法大全

《Python文本相似度计算的方法大全》文本相似度是指两个文本在内容、结构或语义上的相近程度,通常用0到1之间的数值表示,0表示完全不同,1表示完全相同,本文将深入解析多种文本相似度计算方法,帮助您选... 目录前言什么是文本相似度?1. Levenshtein 距离(编辑距离)核心公式实现示例2. Jac

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

MySQL中REPLACE函数与语句举例详解

《MySQL中REPLACE函数与语句举例详解》在MySQL中REPLACE函数是一个用于处理字符串的强大工具,它的主要功能是替换字符串中的某些子字符串,:本文主要介绍MySQL中REPLACE函... 目录一、REPLACE()函数语法:参数说明:功能说明:示例:二、REPLACE INTO语句语法:参数

Python中高级文本模式匹配与查找技术指南

《Python中高级文本模式匹配与查找技术指南》文本处理是编程世界的永恒主题,而模式匹配则是文本处理的基石,本文将深度剖析PythonCookbook中的核心匹配技术,并结合实际工程案例展示其应用,希... 目录引言一、基础工具:字符串方法与序列匹配二、正则表达式:模式匹配的瑞士军刀2.1 re模块核心AP

python中update()函数的用法和一些例子

《python中update()函数的用法和一些例子》update()方法是字典对象的方法,用于将一个字典中的键值对更新到另一个字典中,:本文主要介绍python中update()函数的用法和一些... 目录前言用法注意事项示例示例 1: 使用另一个字典来更新示例 2: 使用可迭代对象来更新示例 3: 使用