abap - 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
没有记录,我期待在这里转储。但事实证明,它是从bsid
into中选择所有记录lt_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.
推荐阅读
- webpack - Webpack 无法解析不在当前上下文目录中的文件导入
- xml - 如何在delphi 7中解析xml文件
- string - ConvertFrom-Json 抱怨未终止的字符串
- python - Ren'Py不会安装python模块turtle
- haskell - 如何在 Haskell 中捕获错误并忽略它?
- php - 如何在 Nginx 上将 .php 扩展名重写为没有结尾?
- mule - Mule 4.x 标准战争文件部署示例
- pine-script - 在另一个指标上回测我的策略
- javascript - Javascript:基于格式解析数组字符串
- ios - 如何在 Metal 中绑定 Array Texture 2D