ABAP程序内表中的数量和金额字段  经常会需要合计, SUM和COLLECT 语法都能实现对数量和金额字段的合计。

1. SUM语法 
ABAP中SUM语句比不上EXCEL里的强大;
SUM只能在loop循环中使用,一般和AT-ENDAT配合使用。
使用SUM语句的先决条件包含在loop中使用加法INTO,以及指定的工作区域wa与内部表的行类型兼容。此外,当内部表itab的行类型包含表组件时,不能使用SUM。

DEMO

  1. DATA:
  2. BEGIN OF wa,
  3. col1 TYPE i,
  4. col2 TYPE i,
  5. END OF wa,
  6. itab LIKE TABLE OF wa WITH EMPTY KEY.
  7.  
  8. itab = VALUE #( FOR i = UNTIL i >
  9. FOR j = UNTIL j > i
  10. ( col1 = i col2 = j ) ).
  11.  
  12. LOOP AT itab INTO wa.
  13. AT END OF col1.
  14. SUM.
  15. cl_demo_output=>write( wa ).
  16. ENDAT.
  17. ENDLOOP.
  18. cl_demo_output=>display( wa ).

内表ITAB中有15行数据

显示:

2. COLLECT语法

语法:COLLECT wa INTO itab [result].

此语句将工作区域的内容作为内部表itab中的单行插入,或者将其数值组件的值添加到具有相同主表键的现有行的对应值中。会对 数值型字段:I 类型, QUAN 类型,CURR类型的字段做汇总,字符型字段视为汇总条件,所以COLLECT 一般是用内表中的字符型字段作为KEY值 做汇总。

  1. *&---------------------------------------------------------------------*
  2. *& Report YCX_COLLECT1
  3. *&---------------------------------------------------------------------*
  4. *&
  5. *&---------------------------------------------------------------------*
  6. REPORT ycx_collect1.
  7.  
  8. TYPES:
  9. BEGIN OF line,
  10. key TYPE c LENGTH ,
  11. num TYPE i,
  12. END OF line.
  13. DATA
  14. itab TYPE SORTED TABLE OF line
  15. WITH UNIQUE KEY key.
  16.  
  17. DATA(rnd) = cl_abap_random_int=>create( seed = + sy-uzeit
  18. min =
  19. max = ).
  20.  
  21. DO.
  22. COLLECT VALUE line( key = COND #( LET r = rnd->get_next( ) IN
  23. WHEN r = THEN 'X'
  24. WHEN r = THEN 'Y'
  25. WHEN r = THEN 'Z' )
  26. num = ) INTO itab
  27. ASSIGNING FIELD-SYMBOL(<fs>).
  28. IF <fs>-num = .
  29. EXIT.
  30. ENDIF.
  31. ENDDO.
  32.  
  33. cl_demo_output=>display( itab ).

再比如,通过工厂,物料汇总数量

  1. DATA: BEGIN OF i_mi OCCURS ,
  2. matnr LIKE zhkmi-matnr,
  3. werks LIKE zhkmi-werks,
  4. menge LIKE zhkmi-menge,
  5. END OF i_mi.
  6.  
  7. START-OF-SELECTION.
  8.  
  9. SELECT matnr werks menge
  10. INTO CORRESPONDING FIELDS OF TABLE i_mi
  11. FROM zhkmi.
  12.  
  13. SORT i_mi BY matnr werks.
  14.  
  15. LOOP AT i_mi.
  16. i_collect-zkind = 'P'.
  17. i_collect-matnr = i_mi-matnr.
  18. i_collect-werks = i_mi-werks.
  19. i_collect-menge = i_mi-menge.
  20. COLLECT i_collect.
  21. CLEAR i_collect.
  22. ENDLOOP.

做个简单例子展示 sum和collect 实现汇总:

  1. *&---------------------------------------------------------------------*
  2. *& Report YCX_SUM
  3. *&---------------------------------------------------------------------*
  4. *&
  5. *&---------------------------------------------------------------------*
  6. REPORT ycx_sum.
  7.  
  8. DATA: BEGIN OF line,
  9. col1 TYPE c,
  10. col2 TYPE i,
  11. END OF line.
  12. DATA: itab LIKE line OCCURS ,
  13. lt_collect LIKE line OCCURS WITH HEADER LINE.
  14.  
  15. DO TIMES.
  16. line-col1 = sy-index.
  17. line-col2 = sy-index ** .
  18. APPEND line TO itab.
  19. ENDDO.
  20.  
  21. **显示内表数据
  22. LOOP AT itab INTO line.
  23. WRITE: / line-col1, line-col2.
  24. ENDLOOP.
  25.  
  26. WRITE:/'SUM汇总数据'.
  27. **使用SUM 汇总
  28. LOOP AT itab INTO line.
  29. AT END OF col1.
  30. SUM.
  31. WRITE: / line-col1, line-col2.
  32. ENDAT.
  33. ENDLOOP.
  34.  
  35. WRITE:/'SUM汇(不使用AT END OF)'.
  36. **使用SUM 汇总
  37. LOOP AT itab INTO line.
  38. SUM.
  39. WRITE: / line-col1, line-col2.
  40. ENDLOOP.
  41.  
  42. **使用COLLECT 汇总
  43. LOOP AT itab INTO line.
  44. lt_collect-col1 = line-col1.
  45. lt_collect-col2 = line-col2.
  46. COLLECT lt_collect.
  47. CLEAR: lt_collect.
  48. ENDLOOP.
  49. WRITE:/'COLLECT汇总数据'.
  50.  
  51. LOOP AT lt_collect.
  52. WRITE: / lt_collect-col1, lt_collect-col2.
  53. ENDLOOP.

ABAP_DEMO篇33 SUM和COLLECT的用法的更多相关文章

  1. mysql sum() 求和函数的用法

    查询在record表中 name=? 的 money 加起来的值使用聚和函数 sum() 求和select sum(money) from record t where t.name = ?另外:co ...

  2. ORACLE PL/SQL开发--bulk collect的用法 .

    刚刚在inthirties老大的博客里看到这篇文章,写的不错,正好自己最近在学习PL/SQL,转过来学习学习. ============================================ ...

  3. (转载)OC学习篇之---协议的概念和用法

    在前一篇文章中我们介绍了OC中类的延展,这一篇文章我们在来看一下OC中协议的概念以及用法,协议也是OC中的一个重点,Foundation框架以及我们后面在写代码都会用到. OC中的协议就是相当于Jav ...

  4. Oracle分析函数 — sum, rollup, cube, grouping用法

    本文通过例子展示sum, rollup, cube, grouping的用法. //首先建score表 create table score( class  nvarchar2(20), course ...

  5. ABAP中Collect的用法

    vaule:collect在非数值字段相同的情况下,起到了数值字段汇总作用. 非数值字段不同的情况下,效果和append相同执行插入内表操作,当非数值字段相同的时候,则相当于modify的效果,只不过 ...

  6. oracle中bulk collect into用法

    通过bulk collect减少loop处理的开销 采用bulk collect可以将查询结果一次性地加载到collections中. 而不是通过cursor一条一条地处理. 可以在select in ...

  7. (高级篇)jQuery学习之jQuery Ajax用法详解

    jQuery Ajax在web应用开发中很常用,它主要包括有ajax,get,post,load,getscript等等这几种常用无刷新操作方法,下面我来给各位同学介绍介绍. 我们先从最简单的方法看起 ...

  8. OC学习篇之---协议的概念和用法

    这一篇文章我们在来看一下OC中协议的概念以及用法,协议也是OC中的一个重点,Foundation框架以及我们后面在写代码都会用到. OC中的协议就是相当于Java中的接口(抽象类),只不过OC中的名字 ...

  9. ASP.NET Core 6框架揭秘实例演示[33]:异常处理高阶用法

    NuGet包"Microsoft.AspNetCore.Diagnostics"中提供了几个与异常处理相关的中间件,我们可以利用它们将原生的或者定制的错误信息作为响应内容发送给客户 ...

随机推荐

  1. C++ 数组输出

    C++中输出数组数据分两种情况:字符型数组和非字符型数组 当定义变量为字符型数组时,采用cout<<数组名; 系统会将数组当作字符串来输出,如: ]={'}; cout << ...

  2. Fiddler手机抓包不完全记录

    准备工作: 1.必须确保安装fiddler的电脑和手机在同一个wifi环境下 备注:如果电脑是笔记本当然最好;如果电脑用的是台式机,可以安装一个随身wifi,来确保台式机和手机在同一wifi环境下   ...

  3. 【java】java 读写文件

    场景:JDK8  将上传的文件,保存到服务器 Java读写文件操作: MultipartFile file InputStream inputStream = file.getInputStream( ...

  4. spring boot EnableAutoConfiguration exclude 无效

    本文链接:https://blog.csdn.net/ID19870510/article/details/79373386 首先讲一下SpringBootApplication注解源码定义为 @Ta ...

  5. prometheus搜索指标显示No datapoints found.

    在指标能够在下拉框可以选择到的情况下,还有No datapoints found. 则考虑是时区的问题,详见官方issue https://github.com/prometheus/promethe ...

  6. datax分析与思考(一)

    Datax 总体流程图 先看执行的第一个步骤: 在最上层抽象类,这个里面相当于获取全局公共信息,java入口部分就是这个Engine的main方法直接启动 Engine 启动 com.alibaba. ...

  7. Django--视图函数

    目录 视图函数 HttpRequest对象 request属性 request常用方法 HttpResponse对象 render() redirect() JsonResponse 视图函数 一个视 ...

  8. Java 字符串(二)字符串常用操作

    一.连接字符串 1.连接多个字符串 使用“+”运算符可以实现连接多个字符串的功能.“+” 运算符可以连接多个运算符并产生一个 String 对象. 2.连接其他数据类型 字符串与其他基本数据类型进行连 ...

  9. Tomcat 8.5版本文件上传后无权限访问的问题

    之前在tomcat 7下文件上传后访问一直没问题,现在tomcat版本升到8.5,在测试文件http上传时,发现所传文件无法通过nginx访问了. (Tomcat具体版本为8.5.11) PS:tom ...

  10. GitHub Vue项目推荐|Vue+Element实现的电商后台管理系统功能丰富

    GitHub Vue项目推荐|mall-admin-web是一个电商后台管理系统的前端项目基于Vue+Element实现 主要包括商品管理.订单管理.会员管理.促销管理.运营管理.内容管理.统计报表. ...