首页 > 解决方案 > FOR ALL ENTRIES 通过空的 itab 选择数据库中的所有记录

问题描述

我有一个正在使用的查询FOR ALL ENTRIES。内部表lt_customer没有记录。

SELECT *
    FROM bsid
    INTO CORRESPONDING FIELDS OF TABLE lt_customer2
    FOR ALL ENTRIES IN lt_customer
    WHERE bukrs EQ p_bukrs
      AND belnr EQ lt_customer-belnr
      AND gjahr EQ lt_customer-gjahr.

现在,由于lt_customer没有记录,我期待在这里转储。但事实证明,它是从bsidinto中选择所有记录lt_customer2。我不明白为什么或如何。请赐教。谢谢!

标签: abapopensql

解决方案


这是标准行为,如 ABAP 帮助中所述:

“如果内部表 itab 为空,则忽略整个 WHERE 条件。”

https://help.sap.com/doc/abapdocu_752_index_htm/7.52/en-US/abenwhere_logexp_itab.htm

在 SELECT 之前检查表是否不为空:

IF lt_customer IS NOT INITIAL.
  SELECT ...
  ...
  FOR ALL ENTRIES IN lt_customer
  ...
ENDIF.

推荐阅读