用键循环遍历动态哈希表

2020-08-17 12:44发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)你好 我正在研究实现IF_RS...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入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

8条回答
N-Moskvin
2020-08-17 13:23

1)使用动态键名按键排序顺序访问表

那么您不能在编程时定义键,但可以在运行时定义它吗? 您要使用表的排序键根据键的排序顺序在记录中循环吗?

"根据基于聚合级别的定义动态地设置您的键名
 数据键名TYPE c长度30。
 案例//IF。
   " ...
   键名='MY_DYN_KEY_NAME'。
   " ...
 ENDCASE//ENDIF。

 环回I_TH_REF_DATA ASSIGNING 使用键(键名)。  "(限制)。
   " ...
 ENDLOOP。

2)动态地从表中获取键名和键属性

我现在不清楚的是,您是否已经在运行时知道该键还是仅知道键组件? 但是,如果您不知道键或键组件,则可以使用GET_KEYS方法在运行时使用类CL_ABAP_TABLEDESCR读取键和组件来获取它们。

数据:lo_tabledescr类型引用到cl_abap_tabledescr,
       lt_keys类型abap_table_keydescr_tab。
 字段符号:与lt_keys相似,
                     类型abap_table_keycompdescr。

 通过数据获取表的键和键组成
 lo_tabledescr?= cl_abap_tabledescr => describe_by_data(I_TH_REF_DATA)。

 lt_keys = lo_tabledescr-> get_keys()。
 在lt_keys ASSIGNING 处循环播放,其中access_kind ='S'"排序模式
                                          AND key_kind ='K'。  "与关键组件
    ",根据以下决定检查是否要使用键 -name:
    " -is_primary'X'是//''否
    " -access_kind'H'散列//'S'排序
    " -is_unique'X'是//''否
    " -key_kind'T'行类型//'K'键组件
    " ...

    循环-组件分配。
    "检查是否要使用关键组件 -name
    " ...

    结局。
 ENDLOOP。

一周热门 更多>