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没有记录,我希望这里有一个转储。但事实证明,它选择了从bsidlt_customer2的所有记录。我不明白为什么或怎么做。请开导我。谢谢!

这是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.

FOR ALL ENTRIES工作方式类似IN运算符。如果itab为空,则忽略此条件。您需要对lt_customer进行手动检查或添加伪记录。

相关内容

  • 没有找到相关文章

最新更新