关于 SAP CRM User Status 处理的示例 ABAP 代码

简介: 关于 SAP CRM User Status 处理的示例 ABAP 代码

源代码如下:

*&---------------------------------------------------------------------*
*& Report ZSTATUS_INITIAL_LOAD
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT zstatus_initial_load.
TYPES:
  BEGIN OF ty_sel_tab,
    sign   TYPE ddsign,
    option TYPE ddoption,
    low    TYPE string,
    high   TYPE string,
  END OF ty_sel_tab .
TYPES:
  tt_sel_tab TYPE STANDARD TABLE OF ty_sel_tab .
DATA: lt_tj30        TYPE STANDARD TABLE OF tj30,
      lv_valid_found TYPE abap_bool,
      lt_option      TYPE tt_sel_tab,
      lt_table       TYPE STANDARD TABLE OF zorder_guid.
SELECT stsma stonr INTO CORRESPONDING FIELDS OF TABLE lt_tj30 FROM tj30.
LOOP AT lt_tj30 ASSIGNING FIELD-SYMBOL(<tj30>).
  AT NEW stsma.
    lv_valid_found = abap_false.
  ENDAT.
  IF <tj30>-stonr IS NOT INITIAL.
    lv_valid_found = abap_true.
  ENDIF.
  AT END OF stsma.
    IF lv_valid_found = abap_true.
      DATA(ls_option) = VALUE ty_sel_tab( sign = 'I' option = 'EQ' low = <tj30>-stsma ).
      APPEND ls_option TO lt_option.
    ENDIF.
  ENDAT.
ENDLOOP.
SELECT guid INTO CORRESPONDING FIELDS OF TABLE lt_table FROM crmd_orderadm_h AS a INNER JOIN crm_jsto AS b
   ON a~guid = b~objnr WHERE b~stsma IN lt_option.
DELETE FROM zorder_guid.
INSERT zorder_guid FROM TABLE lt_table.
COMMIT WORK AND WAIT.
WRITE: / 'table inserted'.
BREAK-POINT.

这段 ABAP 程序的主要作用是从两个 SAP CRM 数据表中检索数据,并将符合特定条件的数据插入到一个自定义的数据表中。程序中还包括一些控制逻辑,用于选择符合条件的数据和执行提交操作。


让我详细解释这段程序的功能以及提供一个示例:


1.程序开始:


  • REPORT zstatus_initial_load.:这一行指定了程序的名称。


2.类型定义:


  • 在程序开始后,定义了两个数据结构(TYPES)。第一个是 ty_sel_tab,用于存储查询选择条件的信息,包括签名(sign)、选项(option)、下限(low)和上限(high)。第二个是 tt_sel_tab,是 ty_sel_tab 类型的标准表格类型。


3.数据声明:


  • DATA 语句用于声明各种数据表和变量,包括 lt_tj30、lv_valid_found、lt_option 和 lt_table。


4.数据查询:


  • SELECT 语句从 tj30 表中选择数据,并将结果存储在 lt_tj30 表中。


5.循环处理:


  • 使用 LOOP 语句遍历 lt_tj30 表中的数据。在每次迭代中,使用 AT NEW stsma 和 AT END OF stsma 控制逻辑来执行某些操作。


6.条件检查:


  • 在循环中,程序检查 <tj30>-stonr 是否为空。如果不为空,将 lv_valid_found 设置为真(abap_true)。


7.数据筛选:


  • 在 AT END OF stsma 控制逻辑内,如果 lv_valid_found 为真,程序创建了一个符合特定条件的选择条件 ls_option,然后将其附加到 lt_option 表中。


8.第二个数据查询:


  • 在循环结束后,程序执行第二个 SELECT 语句,从 crmd_orderadm_h 表和 crm_jsto 表中选择数据,并将结果存储在 lt_table 表中。这个查询使用了之前构建的选择条件 lt_option。


9.数据操作:


  • DELETE FROM zorder_guid.:清空名为 zorder_guid 的自定义数据表。
  • INSERT zorder_guid FROM TABLE lt_table.:将 lt_table 表中的数据插入到 zorder_guid 表中。
  • COMMIT WORK AND WAIT.:提交数据库事务。


10.输出和中断:


  • WRITE: / 'table inserted'.:在屏幕上输出文本消息,表示数据已插入。
  • BREAK-POINT.:插入断点,以便在程序执行期间进行调试。


现在,让我们用一个示例来说明程序的作用:


假设你在一个 SAP CRM 系统中管理客户订单数据。tj30 表包含了订单的状态信息,crmd_orderadm_h 表和 crm_jsto 表包含了订单的详细信息。你想要从 tj30 表中选择符合特定条件的订单状态,并将这些订单的详细信息插入到自定义表 zorder_guid 中。


例如,你想要选择所有订单状态为 ‘Approved’(批准)的订单。在程序执行后,它会遍历 tj30 表,找到所有状态为 ‘Approved’ 的订单,并将它们的详细信息插入到 zorder_guid 表中。最后,屏幕上会显示消息 ‘table inserted’,表示操作已完成。


这是一个简单的示例,说明了程序如何根据选择条件从一个表中选择数据,并将其插入到另一个表中。实际应用中,可以根据具体的业务需求修改程序中的选择条件和数据表,以实现不同的数据处理操作。


相关文章
|
4月前
|
存储 安全 数据库
什么是 SAP ABAP 数据库表的 Display Maintenance Allowed with Restrictions
什么是 SAP ABAP 数据库表的 Display Maintenance Allowed with Restrictions
|
4月前
|
安全 API 数据库
SAP ABAP OData 中 Function import 的概念介绍
SAP ABAP OData 中 Function import 的概念介绍
|
4月前
|
SQL 负载均衡 监控
SAP ABAP DBSQL_SQL_ERROR 错误
SAP ABAP DBSQL_SQL_ERROR 错误
|
4月前
|
前端开发 数据库 开发者
如何在 SEGW 事务码里为 SAP ABAP OData 服务实现 Function Import 试读版
如何在 SEGW 事务码里为 SAP ABAP OData 服务实现 Function Import 试读版
SAP ABAP OData 服务里需要指定 guid 类型的请求参数时,正确语法是什么?
SAP ABAP OData 服务里需要指定 guid 类型的请求参数时,正确语法是什么?
|
4月前
|
SQL 监控 Oracle
SAP ABAP 系统错误 Return value of the database layer SQL dbsl rc 99
SAP ABAP 系统错误 Return value of the database layer SQL dbsl rc 99
|
4月前
|
存储 前端开发 Linux
在 SAP ABAP 系统里访问 FTP 服务器
在 SAP ABAP 系统里访问 FTP 服务器
|
4月前
|
前端开发 搜索推荐 开发者
SAP UI5 sap.m.Column 控件的 minScreenWidth 属性介绍
SAP UI5 sap.m.Column 控件的 minScreenWidth 属性介绍
|
4月前
|
JavaScript 前端开发 开发者
SAP UI5 控件 sap.m.ListBase 的 inset 属性的作用介绍
SAP UI5 控件 sap.m.ListBase 的 inset 属性的作用介绍
|
4月前
|
Web App开发 数据采集 前端开发
纯技术讨论:如何让 SAP UI5 应用无法被别人在浏览器里调试 - 这种做法不推荐试读版
纯技术讨论:如何让 SAP UI5 应用无法被别人在浏览器里调试 - 这种做法不推荐试读版
下一篇
DDNS