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

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

hdu3006状态dp

给你n个集合。集合中均为数字且数字的范围在[1,m]内。m<=14。现在问用这些集合能组成多少个集合自己本身也算。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.Inp

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

cdsapi CDS-Beta

原来版本的cds在 2024年9月26日将不再支持,取而代之的是CDS-Beta。 需要重新更新.cdsapirc以及cdsapi版本,并接受许可。 1.注册获取Personal Access Token CDS-Beta:https://cds-beta.climate.copernicus.eu/ 2.更新.cdsapirc/以及cdsapi版本 https://cds-beta.clima