SAP 创建动态内表

网上找到的比较简单的创建动态内表的方法
原文地址:https://www.cnblogs.com/VerySky/articles/2514436.html
第一种是最简单的

REPORT ZDEMO_SEELE.

PARAMETERS p_name TYPE tabname.

DATA: dyn_table TYPE REF TO data.
DATA: dyn_wa TYPE REF TO data.

FIELD-SYMBOLS: <dyn_table> TYPE table,
               <dyn_wa> TYPE ANY.

*创建动态表结构(动态分配内存)
CREATE DATA dyn_table TYPE TABLE OF (p_name).

*创建动态内表(Field Symbol 的初始化只能指向已存在的内存变量)
ASSIGN dyn_table->* TO <dyn_table>.

*创建动态工作区结构
CREATE DATA dyn_wa LIKE LINE OF <dyn_table>.

*创建动态工作区
ASSIGN dyn_wa->* TO <dyn_wa>.

*从动态表中取数到动态内表中
SELECT * 
INTO CORRESPONDING FIELDS OF TABLE <dyn_table> 
UP TO 100 ROWS 
FROM (p_name).

*对取出数据进行处理
LOOP AT <dyn_table> assigning <dyn_wa>.
 "内表数据处理
ENDLOOP.

*显示内表中的数据
CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
  EXPORTING
    i_structure_name = p_name
  TABLES
    t_outtab         = <dyn_table>
  EXCEPTIONS
    program_error    = 1
    OTHERS           = 2.
IF sy-subrc <> 0.
  MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
          WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
ENDIF.

第二种

REPORT ZDEMO_SEELE.

TYPE-POOLS:abap.

PARAMETERS p_name TYPE tabname.

DATA lt_table TYPE TABLE OF dfies. "字段结构表
DATA ls_table TYPE dfies.

DATA lr_struc TYPE REF TO cl_abap_structdescr.
DATA lr_table TYPE REF TO cl_abap_tabledescr.

DATA lr_type TYPE REF TO cl_abap_typedescr.
DATA lr_data  TYPE REF TO cl_abap_datadescr.

DATA lt_comp TYPE  abap_component_tab.
DATA ls_comp LIKE LINE OF  lt_comp.

DATA dyn_wa TYPE REF TO data.
DATA dyn_table TYPE REF TO data.

DATA l_string TYPE string.

FIELD-SYMBOLS: <dyn_table> TYPE STANDARD TABLE,
                            <dyn_wa> TYPE ANY.

*1.获取表中的所有字段信息
CALL FUNCTION 'DDIF_NAMETAB_GET'
  EXPORTING
    tabname   = p_name
  TABLES
    dfies_tab = lt_table
  EXCEPTIONS
    not_found = 1
    OTHERS    = 2.
IF sy-subrc <> 0.
  MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
          WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
ENDIF.

*读取字段名,获取字段类型
LOOP AT lt_table INTO ls_table.

  CONCATENATE ls_table-tabname '-' ls_table-fieldname INTO l_string.

  ls_comp-name = ls_table-fieldname.
*读取字段类型
  CALL METHOD cl_abap_datadescr=>describe_by_name
    EXPORTING
      p_name         = l_string
    RECEIVING
      p_descr_ref    = lr_type
    EXCEPTIONS
      type_not_found = 1
      OTHERS         = 2.
  IF sy-subrc <> 0.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
               WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.

  ls_comp-type ?= lr_type.
  APPEND ls_comp TO lt_comp.
  CLEAR ls_comp.
ENDLOOP.

*根据字段目录创建动态结构类型
CALL METHOD cl_abap_structdescr=>create
  EXPORTING
    p_components = lt_comp
  RECEIVING
    p_result     = lr_struc.

*根据动态结构创建动态内表类型
CALL METHOD cl_abap_tabledescr=>create
  EXPORTING
    p_line_type = lr_struc
  RECEIVING
    p_result    = lr_table.

*参照动态结构类型和动态内表类型创建内表与工作区
CREATE DATA dyn_wa    TYPE HANDLE lr_struc.
CREATE DATA dyn_table TYPE HANDLE lr_table.

*指定内表与工作区到字段符号
ASSIGN dyn_wa->* TO <dyn_wa>.
ASSIGN dyn_table->* TO <dyn_table>.


*从动态表中取数到动态内表中
  SELECT * 
  INTO CORRESPONDING FIELDS OF TABLE <dyn_table> 
  UP TO 100 ROWS 
  FROM (p_name).

*显示内表中的数据
  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      i_structure_name = p_name
    TABLES
      t_outtab         = <dyn_table>
    EXCEPTIONS
      program_error    = 1
      OTHERS           = 2.
  IF sy-subrc <> 0.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
            WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.

第三种

REPORT ZDEMO_SEELE.
TYPE-POOLS:abap.

PARAMETERS p_name TYPE tabname.

DATA: d_ref TYPE REF TO data,
          lt_alv_cat TYPE TABLE OF lvc_s_fcat,
          ls_alv_cat LIKE LINE OF lt_alv_cat.


DATA: lt_table LIKE TABLE OF dntab.
DATA: ls_table TYPE dntab.


FIELD-SYMBOLS : <dyn_table> TYPE table,
                             <dyn_wa> TYPE ANY,
                             <dyn_field> TYPE ANY.

*取出表结构的字段目录
CALL FUNCTION 'NAMETAB_GET'
  EXPORTING
    langu          = sy-langu
    tabname        = p_name
  TABLES
    nametab        = lt_table
  EXCEPTIONS
    no_texts_found = 1.

*根据取出的字段目录生成参考字段目录
LOOP AT lt_table INTO ls_table.
  ls_alv_cat-fieldname = ls_table-fieldname.
  ls_alv_cat-ref_table = p_name.
  ls_alv_cat-ref_field = ls_table-fieldname.
  APPEND ls_alv_cat TO lt_alv_cat.
  CLEAR ls_alv_cat.
ENDLOOP.

*内表创建
CALL METHOD cl_alv_table_create=>create_dynamic_table
  EXPORTING
    it_fieldcatalog = lt_alv_cat
  IMPORTING
    ep_table        = d_ref.

*指定生成的内表到字段符号
ASSIGN d_ref->* TO <dyn_table>.

*从动态表中取数到动态内表中
  SELECT * 
  INTO CORRESPONDING FIELDS OF TABLE <dyn_table>
  UP TO 100 ROWS 
  FROM (p_name).

*显示内表中的数据
  CALL FUNCTION 'REUSE_ALV_GRID_DISPLAY'
    EXPORTING
      i_structure_name = p_name
    TABLES
      t_outtab         = <dyn_table>
    EXCEPTIONS
      program_error    = 1
      OTHERS           = 2.
  IF sy-subrc <> 0.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
            WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SAP SE11是SAP系统中用于管理表的数据字典工具。它提供了创建、修改和查看表的功能。 首先,我们需要打开SAP SE11工具。在SAP Easy Access菜单中,选择工具 -> ABAP工具 -> 数据字典 (SE11)。或者在SAP Easy Access菜单中直接输入SE11并按回车键。 在打开的SE11界面中,我们可以看到左侧的导航栏,其中包含了数据字典的各种选项。我们点击"表"选项。 接下来,我们可以点击工具栏上的"创建"按钮,开始创建表。在创建表的过程中,我们需要填写一些表的基本信息,如表名、描述等。这些信息可以帮助我们更好地理解和使用表。 在填写完表的基本信息后,我们需要定义表的字段。对于每个字段,我们需要指定字段名、数据类型、长度等属性。在这一步中,我们可以根据具体的需求来定义表的字段。 在定义完表的字段后,我们可以通过点击工具栏上的"保存"按钮,保存表的设计。这样,表就会被创建并保存在数据字典中。 创建表后,我们可以通过SE11工具来查看和修改表的定义。我们可以在导航栏中选择表,然后输入表名,点击"显示"按钮,即可查看表的详细信息。 总结起来,使用SAP SE11创建表可以通过打开SE11工具,选择"表"选项,点击工具栏上的"创建"按钮,填写表的基本信息并定义表的字段,最后保存表的设计。创建好的表可以随时通过SE11工具进行查看和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值