如何在ABAP中使用集(Sets)

2024-02-05 13:18
文章标签 使用 sets abap

本文主要是介绍如何在ABAP中使用集(Sets),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

合理地使用集,能有效避免硬编码,增加程序的可维护性和灵活性。本文以实现资产负债表的报表项为例,讲解 Set 的用法以及 ABAP 中如何获取 Set 的值。

维护集合 (Set)

在 SAP 中,通过下面的事务码维护集

  • GS01: 创建集
  • GS02: 修改集
  • GS03: 显示集
  • GS04: 删除集

SAP 支持 4 种类型的集:

  • 基本集(basic set):在集中保存单一维度的值。比如以报表项为基础建立基本集,每一个报表项由会计科目的范围组成。在创建 Set 的时候,需要指定参照的数据库表和字段。

回车后输入参照的字段:

然后维护 ASST020 所包括的科目范围。每一行可以是单值,也可以是一个范围,允许多行。界面非常直观:

  • 单维集 (single set):由 single set 构成的集,用于表示层次结构。比如基于 basic set 创建的 ZBS,用于表示资产负债表的所有报表项。

  • 多维集(multi set): 由 basic set 和 single set构成的集合
  • 指标集(key figure): 用于 report painter

集的数据表

SAP 对 set 主要存储在下面几个表中:

  • setheader: set header and directory。比如 ASST020,在 setheader 表中存储形式如下:

  • setleaf: 存储 set 的值。比如 ASST020,在 setleaf 表中存储如下:

如何获取 set 的值

SAP 提供下面几个函数用于获取 set 的值

  • G_SET_GET_ID_FROM_NAME:根据 set name 获取 set id。set name 是 GS01 创建的时候使用的 name,比如 asst020。这个 id 用于后面两个函数中,根据 set id 获取对应的值。
  • G_SET_GET_ALL_VALUES: 根据 set id 获取 set 的所有值
  • G_SET_FETCH: 根据 set id 获取 set 的子项

下面演示如何通过这几个函数,获取 ZBS 集合中的所有值

report  z_set_test.data setid        like sethier-setid.
data: setvalues    type standard table of rgsb4 with header line.start-of-selection.call function 'G_SET_GET_ID_FROM_NAME'exportingshortname = 'ZBS'importingnew_setid = setid.call function 'G_SET_GET_ALL_VALUES'exportingsetnr      = setidtablesset_values = setvalues.loop at setvalues.write: / setvalues-shortname,setvalues-field,setvalues-from,setvalues-to.endloop.

程序运行结果如下:

也可以使用 G_SET_FETCH 函数来获取 set 的值:

report  z_set_test.data setid        like sethier-setid.
data: setvalues    type standard table of rgsb4 with header line,single_lines type standard table of rgsb1 with header line,basic_lines  type standard table of rgsbv with header line.start-of-selection.call function 'G_SET_GET_ID_FROM_NAME'exportingshortname = 'ZBS'importingnew_setid = setid.call function 'G_SET_FETCH'exportingsetnr            = setidtablesset_lines_single = single_lines.loop at single_lines.call function 'G_SET_FETCH'exportingsetnr           = single_lines-setnrtablesset_lines_basic = basic_lines.loop at basic_lines.write: / single_lines-setnr,basic_lines-title,basic_lines-from,basic_lines-to.endloop.endloop.

程序运行界面如下:

也可以直接调用 G_SET_GET_ALL_VALUES 函数获取 set 的值,使用方法如下:

report  z_set_test.data setid        like sethier-setid.
data: setvalues    type standard table of rgsb4 with header line.start-of-selection.call function 'G_SET_GET_ALL_VALUES'exportingclient     = sy-mandtsetnr      = 'ZBS'table      = 'SKB1'class      = '0000'fieldname  = 'SAKNR'tablesset_values = setvalues.loop at setvalues.write: / setvalues-shortname,setvalues-field,setvalues-from,setvalues-to.endloop.

源码

abap-practice/Set-Test

这篇关于如何在ABAP中使用集(Sets)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/681026

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

如何使用Lombok进行spring 注入

《如何使用Lombok进行spring注入》本文介绍如何用Lombok简化Spring注入,推荐优先使用setter注入,通过注解自动生成getter/setter及构造器,减少冗余代码,提升开发效... Lombok为了开发环境简化代码,好处不用多说。spring 注入方式为2种,构造器注入和setter

MySQL中比较运算符的具体使用

《MySQL中比较运算符的具体使用》本文介绍了SQL中常用的符号类型和非符号类型运算符,符号类型运算符包括等于(=)、安全等于(=)、不等于(/!=)、大小比较(,=,,=)等,感兴趣的可以了解一下... 目录符号类型运算符1. 等于运算符=2. 安全等于运算符<=>3. 不等于运算符<>或!=4. 小于运

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4

Python 字典 (Dictionary)使用详解

《Python字典(Dictionary)使用详解》字典是python中最重要,最常用的数据结构之一,它提供了高效的键值对存储和查找能力,:本文主要介绍Python字典(Dictionary)... 目录字典1.基本特性2.创建字典3.访问元素4.修改字典5.删除元素6.字典遍历7.字典的高级特性默认字典

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定