ABAP 动态内表,操作动态内表

2024-04-10 17:12
文章标签 动态 操作 abap 内表

本文主要是介绍ABAP 动态内表,操作动态内表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.定义:

DATA:DY_TABLE TYPE REF TO DATA,WA_NEW_LINE TYPE REF TO DATA,
     ET_FIELDCAT TYPE LVC_T_FCAT ,ES_FIELDCAT TYPE LVC_S_FCAT,
     LV_STRFIELD TYPE C LENGTH 25,ITEM TYPE I.

FIELD-SYMBOLS:<FS_TABLE> TYPE STANDARD TABLE,<DYN_WA>,<DYN_FIELD> .

DATA:W_IT_FIELD TYPE ABAP_SORTORDER_TAB,W_STR_FIELD TYPE ABAP_SORTORDER.


2.赋值:

CLEAR:ET_FIELDCAT,ES_FIELDCAT.REFRESH :ET_FIELDCAT.

ES_FIELDCAT-COL_POS = 1.
ES_FIELDCAT-FIELDNAME = 'ITEM'.
ES_FIELDCAT-COLTEXT = '序号'.
ES_FIELDCAT-OUTPUTLEN = '5'.
ES_FIELDCAT-INTTYPE = 'I'."'C'
APPEND ES_FIELDCAT TO ET_FIELDCAT.
CLEAR ES_FIELDCAT.

3.创建:

CALL METHOD CL_ALV_TABLE_CREATE=>CREATE_DYNAMIC_TABLE
  EXPORTING
    IT_FIELDCATALOG = ET_FIELDCAT
  IMPORTING
    EP_TABLE        = DY_TABLE.
ASSIGN DY_TABLE->* TO <FS_TABLE>."创建动态内表

CREATE DATA WA_NEW_LINE LIKE LINE OF <FS_TABLE>.
ASSIGN WA_NEW_LINE->* TO <DYN_WA>.

4.操作

"增加动态内表的值
CLEAR ITEM.
DO 2 TIMES.
  ITEM = ITEM + 1.
  ASSIGN COMPONENT 'ITEM' OF STRUCTURE <DYN_WA> TO <DYN_FIELD>."动态内表字段
  <DYN_FIELD> = ITEM.
  APPEND <DYN_WA> TO <FS_TABLE>.
  CLEAR <DYN_WA> .
ENDDO.

"循环内表+更新
LOOP AT <FS_TABLE> INTO <DYN_WA>.
  ITEM = ITEM + 1.
  ASSIGN COMPONENT 'ITEM' OF STRUCTURE <DYN_WA> TO <DYN_FIELD>." <DYN_FIELD>的值等于<FS_TABLE>-ITEM 字段的值
  <DYN_FIELD> = ITEM.
  MODIFY <FS_TABLE> FROM <DYN_WA>.
ENDLOOP.

"删除

DELETE <FS_TABLE> INDEX 1.
LOOP AT <FS_TABLE> INTO <DYN_WA>.
  ASSIGN COMPONENT 'ITEM' OF STRUCTURE <DYN_WA> TO <DYN_FIELD>.
  IF <DYN_FIELD> = 4.
    DELETE <FS_TABLE>.
  ENDIF.
ENDLOOP.

5.排序:

W_STR_FIELD-NAME = 'ITEM'.
W_STR_FIELD-DESCENDING = 'X'."'X' DESC ,'' ASC
APPEND W_STR_FIELD TO W_IT_FIELD.
SORT <FS_TABLE> BY (W_IT_FIELD).

这篇关于ABAP 动态内表,操作动态内表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

Python使用Code2flow将代码转化为流程图的操作教程

《Python使用Code2flow将代码转化为流程图的操作教程》Code2flow是一款开源工具,能够将代码自动转换为流程图,该工具对于代码审查、调试和理解大型代码库非常有用,在这篇博客中,我们将深... 目录引言1nVflRA、为什么选择 Code2flow?2、安装 Code2flow3、基本功能演示

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re