顾问给我发送了这个代码示例,这是他希望得到的东西
SELECT m1~vbeln_im m1~vbelp_im m1~mblnr smbln
INTO CORRESPONDING FIELDS OF TABLE lt_mseg
FROM mseg AS m1
INNER JOIN mseg AS m2 ON m1~mblnr = m2~smbln
AND m1~mjahr = m2~sjahr
AND m1~zeile = m2~smblp
FOR ALL ENTRIES IN lt_vbfa
WHERE
AND m2~bwart = '102'
AND 0 = ( select SUM( ( CASE
when SHKZG = 'S' THEN 1
when SHKZG = 'H' THEN -1
else 0
END ) *MENGE ) MENGE
into lt_mseg-summ
from mseg
where
VBELN_IM = m1~vbeln_im
and VBELP_IM = m1~vbelp_im
).
问题是我不知道在当前语法中应该如何工作。我考虑派生内部选择并将其用作主选择的条件,但是有没有正确的方法来编写这种嵌套结构?
据我所知,如果嵌套语句 = 0,则执行主查询。这里的问题是嵌套语句中的 case。在ABAP中甚至可能吗?在我看来,这个检查可以在主 SQL 查询之外使用。
欢迎任何建议。
最佳答案
您得到的逻辑是 Native/Open SQL 的一部分,并且有一些您需要注意的缺点。
对我来说,我会研究一种更好的方法来捕获在开放/ native sql 之外性能更好的数据。
如果您想推进这种类型的逻辑,下面有几个链接应该会有所帮助。有一个使用带有 case 语句的嵌套选择的示例选择。
Test Program
Example Logic
关于subquery - FOR ALL ENTRIES 中的嵌套子查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36148811/