点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)你好 我正在研究实现IF_RS...
点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)你好 我正在研究实现IF_RS...
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
你好
我正在研究实现IF_RSPLFA_SRVTYPE_IMP_EXEC_REF(参考数据计划)的自定义计划功能类型。
实现类的EXECUTE方法具有I_TH_REF_DATA TYPE HASHED TABLE作为"导入"参数。 该表实际上包括我的参考数据。 该表的结构是在运行时根据聚合级别的结构动态定义的。 它包含构成聚合级别的所有特征和关键数据。
为避免对表进行全面扫描,我想使用某种"部分"键(仅包含有限的一组特征)遍历该表。 产品协助建议如下:
DATA spfli_tab类型哈希表 OF SPFLI 使用唯一键primary_key 成分carrid connid 使用非唯一排序键city_from_to 组件城市从城市到 使用非唯一排序键city_to_from 组件从城市到城市。 循环至spfli_tab分配使用密钥city_from_to。
但是。 不适用于我的任务,因为表I_TH_REF_DATA是在计划引擎内部定义的,我无法控制其结构(包括键)。
我事先知道聚合级别的结构,并且想使用一个包含0FISCPER,0CURRENCY,ZSCOPE和ZVERSION特性的键进行循环。 我需要类似的东西
在I_TH_REF_DATA分配处循环使用关键组件'0FISCPER''0CURRENCY''ZSCOPE''ZVERSION'
但是,似乎ABAP语法没有为此提供
。请告知,如何遍历动态哈希表以避免全表扫描?
谢谢
Val
嗨,Val,
参数I_TH_REF_DATA是按值传递的,因此只需进行动态排序(是的,可以对哈希表进行排序),然后执行 通常的组更改逻辑。 因此,在I_TH_REF_DATA的循环中,您只需填充一个本地表,并在任何新的组合中都可以使用从先前组合中收集的记录来调用您的方法。 您不需要此处的唯一组合表。
这也无需排序即可使用,但是您必须先收集一组中包含的记录,例如 在唯一组合表的非关键部分。 这样做的缺点是您必须复制记录(或使用引用)。
我不明白您为什么担心全表扫描,无论如何您解释的逻辑都需要全表扫描 。
我认为第一种选择既简单又有效。 观察到SORT ...是ABAP内核中的一条语句,因此它很快。
问候
Gregor
一周热门 更多>