ABAP - SALV教程16 合计、小计

2024-03-04 08:12
文章标签 16 教程 abap 合计 小计 salv

本文主要是介绍ABAP - SALV教程16 合计、小计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  • 虽然ALV的标准状态栏功能就能实现合计、小计、平均值、最大值等这些功能,但用户更希望一进去ALV就希望ALV已经对数量,金额的字段进行合计,小计。
  • SALV实现合计,调用CL_SALV_AGGREGATIONS的ADD_AGGREGATION即可
        DATA(lo_aggrs) = co_alv->get_aggregations( ).TRY."给NETWR字段添加合计lo_aggrs->add_aggregation( EXPORTINGcolumnname  = 'NETWR'aggregation = if_salv_c_aggregation=>total).CATCH cx_salv_data_error .CATCH cx_salv_not_found .CATCH cx_salv_existing .ENDTRY."将合计放置到NETWR字段的顶端"lo_aggrs->set_aggregation_before_items(NETWR )."将合计跟随在NETWR字段的底部lo_aggrs->set_aggregation_allowed( 'NETWR' ).
    

  • SALV在合计前提下排序时会自动小计,实调用类CL_SALV_SORTS的GET_SORT方法即可
        DATA(lo_sorts) = co_alv->get_sorts( ).TRY."对销售订单号进行排序,由于有总计,所以每个销售订单也会有小计lo_sorts->add_sort( EXPORTINGcolumnname = 'VBELN'subtotal   = if_salv_c_bool_sap=>true).CATCH cx_salv_not_found .                         "#EC NO_HANDLERCATCH cx_salv_existing .                          "#EC NO_HANDLERCATCH cx_salv_data_error .                        "#EC NO_HANDLERENDTRY.

  • 显示效果如下图所示 


  • 完整代码
    CLASS lcl_model DEFINITION.PUBLIC SECTION.TYPES:BEGIN OF TY_dATA,vbeln TYPE vbak-vbeln,erdat TYPE erdat,erzet TYPE erzet,ernam TYPE ernam,auart TYPE auart,netwr TYPE netwr.TYPES:END  OF ty_data.DATA mt_data TYPE TABLE OF ty_data.DATA mo_salv TYPE REF TO cl_salv_table."获取数据的方法METHODS get_data."展示SALV的方法METHODS alv_show.PRIVATE SECTION.METHODS:set_stats CHANGING co_alv TYPE REF TO cl_salv_table.METHODS:set_sorts CHANGING co_alv TYPE REF TO cl_salv_table.METHODS:set_aggrs CHANGING co_alv TYPE REF TO cl_salv_table.
    ENDCLASS.CLASS lcl_model IMPLEMENTATION.METHOD get_data.SELECT vbeln erdat erzet ernam auart netwrINTO TABLE mt_dataFROM vbakUP TO 10 ROWS.ENDMETHOD.METHOD alv_show.DATA: lx_msg TYPE REF TO cx_salv_msg.TRY.cl_salv_table=>factory(IMPORTINGr_salv_table = mo_salvCHANGINGt_table      = mt_data ).CATCH cx_salv_msg INTO lx_msg.ENDTRY.me->set_stats( CHANGING co_alv = mo_salv ).me->set_aggrs( CHANGING co_alv = mo_salv ).me->set_sorts( CHANGING co_alv = mo_salv ).mo_salv->display( ).ENDMETHOD.METHOD set_stats.DATA(lo_functions) = co_alv->get_functions( )."cl_salv_functions_list类型的实例对象的添加状态方法lo_functions->set_all( abap_true )."lo_functions->set_default( abap_true ).ENDMETHOD.METHOD set_sorts.DATA(lo_sorts) = co_alv->get_sorts( ).TRY."对销售订单号进行排序,由于有总计,所以每个销售订单也会有小计lo_sorts->add_sort( EXPORTINGcolumnname = 'VBELN'subtotal   = if_salv_c_bool_sap=>true).CATCH cx_salv_not_found .                         "#EC NO_HANDLERCATCH cx_salv_existing .                          "#EC NO_HANDLERCATCH cx_salv_data_error .                        "#EC NO_HANDLERENDTRY.ENDMETHOD.METHOD set_aggrs.DATA(lo_aggrs) = co_alv->get_aggregations( ).TRY."给NETWR字段添加合计lo_aggrs->add_aggregation( EXPORTINGcolumnname  = 'NETWR'aggregation = if_salv_c_aggregation=>total).CATCH cx_salv_data_error .CATCH cx_salv_not_found .CATCH cx_salv_existing .ENDTRY."将合计放置到NETWR字段的顶端"lo_aggrs->set_aggregation_before_items(NETWR )."将合计跟随在NETWR字段的底部lo_aggrs->set_aggregation_allowed( 'NETWR' ).ENDMETHOD.ENDCLASS.START-OF-SELECTION.DATA(lo_model) = NEW lcl_model( ).lo_model->get_data( ).lo_model->alv_show( )
     

这篇关于ABAP - SALV教程16 合计、小计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772569

相关文章

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Linux系统中卸载与安装JDK的详细教程

《Linux系统中卸载与安装JDK的详细教程》本文详细介绍了如何在Linux系统中通过Xshell和Xftp工具连接与传输文件,然后进行JDK的安装与卸载,安装步骤包括连接Linux、传输JDK安装包... 目录1、卸载1.1 linux删除自带的JDK1.2 Linux上卸载自己安装的JDK2、安装2.1

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

springboot简单集成Security配置的教程

《springboot简单集成Security配置的教程》:本文主要介绍springboot简单集成Security配置的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录集成Security安全框架引入依赖编写配置类WebSecurityConfig(自定义资源权限规则

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Linux安装MySQL的教程

《Linux安装MySQL的教程》:本文主要介绍Linux安装MySQL的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux安装mysql1.Mysql官网2.我的存放路径3.解压mysql文件到当前目录4.重命名一下5.创建mysql用户组和用户并修

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言