SAP 关于DELETE的用法

sort itab by matkl .
  delete adjacent duplicates from itab comparing  matkl.
uline at /1(70).

---------------------------------------------------------------------------

在使用abap delete duplicate时发现删除重复记录不完全。

只删除掉了部分重复记录。最后经过调试,没发现其它问题。于是再次研究delete duplicate语法

发现delete duplicate只删除相邻行的重复项,保留第一条记录,所以在对内表进行delete duplicate

操作时应该注意先对内表进行排序,然后再执行delete duplicate语句,即可将重复项完全删除。

排序注意点:升序 sort itab (ascending),降序 sort itab descending.

附:

ABAP delete duplicate的用法指南
DELETE ADJACENT DUPLICATE ENTRIES FROM  
                                  [COMPARING ... 
                                             |ALL FIELDS].
删除相邻行的重复项,保留第一条记录
1、如果没有定义non-nuique键,并且在删除的时候没有指定条件,则将比较所有的字段;等同于比较
DELETE ADJACENT DUPLICATES FROM ITAB COMPARING ALL FIELDS
定义non-unique字段方式如下:
DATA ITAB LIKE STANDARD TABLE OF LINE
          WITH NON-UNIQUE KEY COL2.
2、如果有non-unique键,则在没有删除的比较条件时比较该key,删除相邻的重复项。
3、可以使用指定条件进行比较处理 COMPARING ... ,此时,需要所有指定字段在相邻处相同,否则不会删除。


其他补充说明:
如果对比较的字段进行了事先的排序,则可以将所有该字段重复的行全部删除。
如果至少删除成功一条,则sy-subrc返回0,否则返回4.

你可能感兴趣的:(ABAP技术,sql,mysql,servlet,开发语言,服务器)