本文介绍了通过分组在 ABAP 内部表中查找重复项的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我们都知道这些出色的 ABAP 语句,它们允许在单行中找到独特的值:

We all know these excellent ABAP statements which allows finding unique values in one-liner:

it_unique = VALUE #( FOR GROUPS value OF <line> IN it_itab
                     GROUP BY <line>-field WITHOUT MEMBERS ( value ) ).

但是提取重复项呢?是否可以为该任务使用 GROUP BY 语法,或者表推导式在这里更有用?

But what about extracting duplicates? Can one utilize GROUP BY syntax for that task or, maybe, table comprehensions are more useful here?

我发现的唯一(虽然不是很优雅)的方法是:

The only (though not very elegant) way I found is:

LOOP AT lt_marc ASSIGNING FIELD-SYMBOL(<fs_marc>) GROUP BY ( matnr = <fs_marc>-matnr
                                                             werks = <fs_marc>-werks )
                                                  ASSIGNING FIELD-SYMBOL(<group>).
  members = VALUE #( FOR m IN GROUP <group> ( m ) ).

  IF lines( members ) > 1.
    "throw error
  ENDIF.

ENDLOOP.

有没有更漂亮的方法可以通过任意键查找重复项?

Is there more beautiful way of finding duplicates by arbitrary key?

推荐答案

所以,我只是把它作为答案,因为我们和 Florian 无法想出更好的办法.
如果有人能够改进它,那就去做吧.

So, I just put it as answer, as we with Florian weren't able to think out something better.
If somebody is able to improve it, just do it.

TYPES tt_materials TYPE STANDARD TABLE OF marc WITH DEFAULT KEY.

DATA duplicates TYPE tt_materials.
LOOP AT materials INTO DATA(material)
GROUP BY ( id = material-matnr
           status = material-pstat
           size = GROUP SIZE )
ASCENDING REFERENCE INTO DATA(group_ref).

CHECK group_ref->*-size > 1.
duplicates = VALUE tt_materials( BASE duplicates FOR <status> IN GROUP group_ref ( <status> ) ).

ENDLOOP.

这篇关于通过分组在 ABAP 内部表中查找重复项的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

06-04 06:58