在 ABAP 中使用一个或多个 IF 语句的 SELECT 查询

Posted

技术标签:

【中文标题】在 ABAP 中使用一个或多个 IF 语句的 SELECT 查询【英文标题】:SELECT query with one or multiple IF statements in ABAP 【发布时间】:2021-12-27 09:17:55 【问题描述】:

我正在开发一项网络服务。我有一个这样的 select 语句(它比这有更多的字段和 2 个连接,但为了保持简单):

SELECT acdoca~augbl,
       open_amount,    "I need to add value to this field based on the IF statement below
       acdoca~koart
FROM acdoca
      LEFT JOIN bseg ON acdoca~belnr EQ bseg~belnr
                      AND acdoca~gjahr EQ bseg~gjahr
                      AND acdoca~buzei EQ bseg~buzei
                      AND acdoca~rbukrs EQ bseg~bukrs
INTO table @it_acdoca.

我需要添加这个 IF 语句:

IF bseg-KOART = 'D' or bseg-KOART = 'K' 
    IF acdoca-AUGBL is INITIAL THEN open_amount = DMBTR
        ELSE open_amount = 0
    ENDIF.
ELSE open_amount = 0
ENDIF.

我需要一个不会影响服务性能的答案。因为 ACDOCA 和 BSEG 是 SAP 中一些最大的数据库表。我尝试在 SELECT 之后使用 LOOP,然后在该 LOOP 中添加这个 IF,但这完全破坏了性能。

This Is What IT_ACDOCA table should look like after

希望快速回复。 最好的问候。

【问题讨论】:

如果您担心 ACDOCA 性能,请使用CTE 或CDS 是的,不要直接使用 ACDOCA(或任何其他表)!它非常大,里面有很多语义,而且还在不断变化。您将 (a) 无法获得您想要的结果或 (b) 您的逻辑将在未来停止工作或 (c) 性能很糟糕。而是使用特定于您的用例的已发布 CDS 实体之一,例如 I_SalesOrderItem 或类似的。有了这个,您有 (1) 适当的授权检查,(2) 清除迁移路径以防发生变化,以及 (3) 您不必维护连接 :) 【参考方案1】:
DATA: BEGIN OF it_acdoca  OCCURS 0,
        augbl       TYPE acdoca-augbl,
        open_amount TYPE bseg-dmbtr,
        koart       TYPE acdoca-koart.
DATA: END OF it_acdoca.

SELECT acdoca~augbl,
       CASE WHEN ( bseg~koart EQ 'D' OR bseg~koart EQ 'K' ) AND acdoca~AUGBL is INITIAL THEN dmbtr
         ELSE 0
   END AS open_amount,
       acdoca~koart
FROM acdoca
      LEFT JOIN bseg ON acdoca~belnr EQ bseg~belnr
                      AND acdoca~gjahr EQ bseg~gjahr
                      AND acdoca~buzei EQ bseg~buzei
                      AND acdoca~rbukrs EQ bseg~bukrs
INTO TABLE @it_acdoca.

如果您的版本不支持 CASE,您可以将您的语句添加到 JOIN 端,如下所示。

SELECT acdoca~augbl,
       dmbtr AS open_amount,
       acdoca~koart
FROM acdoca
      LEFT JOIN bseg ON acdoca~belnr EQ bseg~belnr
                      AND acdoca~gjahr EQ bseg~gjahr
                      AND acdoca~buzei EQ bseg~buzei
                      AND acdoca~rbukrs EQ bseg~bukrs
                      AND ( bseg~koart EQ 'D' OR bseg~koart EQ 'K' )
                      AND acdoca~AUGBL is INITIAL
INTO TABLE @it_acdoca.

【讨论】:

尊敬的 mkysoft,感谢您的回答,案例陈述部分解决了我的问题。第二部分对我不起作用,因为我在选择中有更多字段,这些字段将通过在 JOIN 中添加这些行来实现。不过,感谢您的帮助!

以上是关于在 ABAP 中使用一个或多个 IF 语句的 SELECT 查询的主要内容,如果未能解决你的问题,请参考以下文章

ABAP中的报出消息语句的关键字是啥?请至少说出三种消息类型.消息文本使用哪个TC

关於在ABAP中的SELECT语句的一种用法的请教。

在 C# 中使用带有多个 if 语句的 else

Visual Studio 跳过多个 if 语句?

ABAP性能和优化

ABAP如何将数据库表导出