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获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

微信公众号脚本-获取热搜自动新建草稿并发布文章

《微信公众号脚本-获取热搜自动新建草稿并发布文章》本来想写一个自动化发布微信公众号的小绿书的脚本,但是微信公众号官网没有小绿书的接口,那就写一个获取热搜微信普通文章的脚本吧,:本文主要介绍微信公众... 目录介绍思路前期准备环境要求获取接口token获取热搜获取热搜数据下载热搜图片给图片加上标题文字上传图片

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

使用Python实现获取网页指定内容

《使用Python实现获取网页指定内容》在当今互联网时代,网页数据抓取是一项非常重要的技能,本文将带你从零开始学习如何使用Python获取网页中的指定内容,希望对大家有所帮助... 目录引言1. 网页抓取的基本概念2. python中的网页抓取库3. 安装必要的库4. 发送HTTP请求并获取网页内容5. 解

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

使用Python实现文本转语音(TTS)并播放音频

《使用Python实现文本转语音(TTS)并播放音频》在开发涉及语音交互或需要语音提示的应用时,文本转语音(TTS)技术是一个非常实用的工具,下面我们来看看如何使用gTTS和playsound库将文本... 目录什么是 gTTS 和 playsound安装依赖库实现步骤 1. 导入库2. 定义文本和语言 3

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解