在ALV提供的标准工具栏上我们可以实现输出结果的聚合(最大值,最小值,汇总,平均数),排序,过滤功能,同样在程序里也可以达到这些功能。

1.       声明聚合,排序,过滤所需要的变量。

DATA: lr_aggregations TYPE REF TO cl_salv_aggregations,

lr_filters       TYPE REF TO cl_salv_filters,

lr_sorts          type ref to cl_salv_sorts.

2.      汇总

lr_aggregations->add_aggregation(

columnname = 'DISTANCE'

aggregation =if_salv_c_aggregation=>total

).

3.     最小值

lr_aggregations->add_aggregation(

columnname = 'FLTIME'

aggregation = if_salv_c_aggregation=>minimum

).

4.       过滤

lr_filters->add_filter(

columnname = 'CITYFROM'

sign = 'I'

option = 'NE'

low = 'ROM'

high = ''

).

5.       排序

lr_sorts->add_sort(

columnname = 'CITYFROM'

sequence =if_salv_c_sort=>sort_down

subtotal = 'X'

obligatory = 'X'

).

下面是效果图

下面是程序的所有代码:

REPORT  y_xin_002.

*变量定义

TYPES: BEGIN OF gs_spfli,

mandt       TYPE spfli-mandt,

carrid      TYPE spfli-carrid,

connid      TYPE spfli-connid,

countryfr   TYPE spfli-countryfr,

cityfrom    TYPE spfli-cityfrom,

airpfrom    TYPE spfli-airpfrom,

countryto   TYPE spfli-countryto,

cityto      TYPE spfli-cityto,

airpto      TYPE spfli-airpto,

fltime      TYPE spfli-fltime,

deptime     TYPE spfli-deptime,

arrtime     TYPE spfli-arrtime,

distance    TYPE spfli-distance,

distid      TYPE spfli-distid,

fltype      TYPE spfli-fltype,

period      TYPE spfli-period,

END OF gs_spfli.

TYPES  ty_spfli TYPE gs_spfli OCCURS 0.

*----------------------------------------------------------------------*

*       CLASS lcl_alv DEFINITION

*----------------------------------------------------------------------*

*       ALV操作类(定义)

*----------------------------------------------------------------------*

CLASS lcl_alv DEFINITION.

PUBLIC SECTION.

METHODS: getdata               "取得要显示的数据

RETURNING value(lt_tab) TYPEty_spfli,

alv_full              "全屏Grid列表处理方法

IMPORTING value(lt_tab) TYPEty_spfli.

PRIVATE SECTION.

DATA: gr_table TYPE REF TO cl_salv_table.

ENDCLASS.                    "lcl_alv DEFINITION

*----------------------------------------------------------------------*

*       CLASS lcl_alv IMPLEMENTATION

*----------------------------------------------------------------------*

*       ALV操作类(实现)

*----------------------------------------------------------------------*

CLASS lcl_alvIMPLEMENTATION.

*取得要显示的数据

METHOD getdata.

SELECT * INTO CORRESPONDING FIELDS OF TABLElt_tab FROM spfli.

ENDMETHOD.                    "getdata

*输出全屏网格列表的方法

METHOD alv_full.

DATA: lr_functions    TYPE REF TO cl_salv_functions_list,

lr_aggregations TYPE REF TO cl_salv_aggregations,

lr_filters      TYPE REF TO cl_salv_filters,

lr_sorts        type ref to cl_salv_sorts.

"创建实例

TRY.

cl_salv_table=>factory(

IMPORTING

r_salv_table = gr_table

CHANGING

t_table      = lt_tab

).

CATCH cx_salv_msg.

ENDTRY.

"ALV标准功能

lr_functions = gr_table->get_functions().

lr_functions->set_all( 'X' ).

lr_aggregations =gr_table->get_aggregations( ).

lr_filters      = gr_table->get_filters( ).

lr_sorts        = gr_table->get_sorts( ).

TRY.

"汇总

lr_aggregations->add_aggregation(

columnname = 'DISTANCE'

aggregation =if_salv_c_aggregation=>total

).

"最小值

lr_aggregations->add_aggregation(

columnname = 'FLTIME'

aggregation =if_salv_c_aggregation=>minimum

).

"过滤

lr_filters->add_filter(

columnname = 'CITYFROM'

sign = 'I'

option = 'NE'

low = 'ROM'

high = ''

).

"排序

lr_sorts->add_sort(

columnname = 'CITYFROM'

sequence =if_salv_c_sort=>sort_down

subtotal = 'X'

obligatory = 'X'

).

CATCH cx_salv_data_error.

CATCH cx_salv_existing.

CATCH cx_salv_not_found.

ENDTRY.

"显示列表

gr_table->display( ).

ENDMETHOD.                    "alv_full

ENDCLASS.                    "lcl_alvIMPLEMENTATION

*&---------------------------------------------------------------------*

*&      Form f_main

*&---------------------------------------------------------------------*

*       整合数据,执行

*----------------------------------------------------------------------*

FORM f_main.

DATA: lt_tab TYPE ty_spfli,

lr_alv TYPE REF TO lcl_alv.

CREATE OBJECT lr_alv.

"取得要显示的数据

lt_tab = lr_alv->getdata( ).

lr_alv->alv_full( lt_tab ).

ENDFORM.                    "f_main

*执行动作

START-OF-SELECTION.

PERFORM f_main.

OO实现ALV TABLE 十一:ALV的聚合,排序,过滤相关推荐

  1. OO实现ALV TABLE 三:ALV的功能设计

    细心的读者肯定已经注意前面的两个例子少了点什么,少了ALV提供的标准功能,比如排序,过滤,汇总,等,以及用户可以在ALV的功能栏上加上自己自定义的功能按钮. ALV的标准功能可以通过类CL_SALV_ ...

  2. OO实现ALV TABLE 二:ALV显示的三种形式

    一般的ALV有三种显示形式,分别为 一.普通的List 二.全屏的Grid 三.在自定义屏幕的显示的Grid 跟以往实现这三种ALV显示方式相比,以往的三种显示方式分别是调用不同的Function和C ...

  3. WDA学习(9):Use an ALV TABLE in WDA

    实例展示如何使用ALV TABLE在窗口显示航班信息. 1.创建Web Dynpro Component. 2.创建Component Usage,使用SALV_WD_TABLE组件 Context页 ...

  4. 第十一章 SQL聚合函数 SUM

    文章目录 第十一章 SQL聚合函数 SUM 大纲 参数 描述 数据值 优化 当前事务期间所做的更改 示例 第十一章 SQL聚合函数 SUM 返回指定列值之和的聚合函数. 大纲 SUM([ALL | D ...

  5. 19_clickhouse,数据查询与写入优化,分布式子查询优化,外部聚合/排序优化,基于JOIN引擎的优化,SQL优化案例,物化视图提速,查询优化常用经验法则,选择和主键不一样的排序键,数据入库优化

    25.数据查询与写入优化 25.1.分布式子查询优化 25.1.1.分布式表的IN查询示例1(普通IN子查询.IN子查询为本地表) 25.1.2.分布式表的IN查询示例2(普通IN子查询.IN子查询为 ...

  6. React Table 表格组件使用教程 排序、分页、搜索过滤筛选功能实战开发

    React Table 表格组件使用教程 react-table 安装和使用 React Table 表格排序功能 React Table 表格搜索过滤筛选功能 React Table 表格分页功能 ...

  7. ES中如何实现类似having的先聚合再过滤查询

    一.问题描述: 在mysql数据库中,我们可以很方面的通过having关键字实现对聚合结果的过滤查询.那么,在ES中该如何实现类似having的先聚合再过滤查询呢? 二.业务场景: 需要找出下单次数大 ...

  8. ES实现nested类型聚合以及子聚合排序

    ES实现nested类型聚合以及子聚合排序 ES实现nested类型聚合以及子聚合排序 需求业务说明 品牌近7天销量 品牌近7日销量趋势 指定某个sku日期范围销量趋势和价格趋势 电商商品日销量索引m ...

  9. OO实现ALV TABLE 五:ALV的栏位属性

    ALV的栏位属性是SAP提供的ALV功能的比较重要的一个,详细的功能包括异常状态图标.图标.符号.复选框.按钮.热点.超链接.单元格类型.单元格颜色.某一栏位颜色.某一行颜色,栏位隐藏等等.ALV的栏 ...

最新文章

  1. 转-linux系统脚本 环境变量 的启动顺序
  2. 建模的常用手段:组合与聚合
  3. SQL 常用数据类型汇总
  4. python中三级菜单讲解_Python字典实现简单的三级菜单(实例讲解)
  5. day20 Python 高阶函数,函数,嵌套,闭包 装饰器
  6. TCC Demo 代码实现
  7. singft 函数 matlab,(新)信号与系统MATLAB实验全.doc
  8. 无代码开发究竟是不是伪需求?
  9. 调用网易云Api接口实现移动Web网易云部分功能(搜索+列表+播放)
  10. 使用VirtualBox安装Dos系统并配置masm汇编语言环境
  11. 数据结构试题及评分解析
  12. vue-study-1 mvx模式
  13. 【OJ每日一练】1029 - 字母密码
  14. 消息中间件---选型分析
  15. Modeling Task Relationships in Multi-task Learning withMulti-gate Mixture-of-Experts
  16. ElasticSearch windows部署(避坑干货)
  17. 大数据培训—DolphinSchedular(一)
  18. ArcGIS中的TIN与DEM数据的生成
  19. 关于The remote certificate is invalid according to the validation procedure(远程证书验证过程无效)的解决方案
  20. 计算机丢失d3dx9_41.dll,d3dx9_41.dll(支持64位)

热门文章

  1. C++流操纵算子(格式控制)
  2. Linux-Rsync项目实战(详细) 备份全网服务器数据生产架构方案
  3. Curl操作es实践
  4. c/c++的typedef/using类型别名
  5. XML 和 JSON 的使用场景
  6. JqueryMobile链接一个页面,而链接页面中图片需刷新才显示的问题
  7. AIX 6.1 异步 I/O 的 配置与性能评估
  8. 从输入流中获取数据并以字节数组返回
  9. 【摩天好课推荐】1 Python简介
  10. 2021-05-19