#abap #sap-query
#abap #sap-запрос
Вопрос:
У меня есть основная таблица EKPO, присоединенная к таблицам MLGN и MLGT в качестве внешних соединений.
Я создал дополнительное поле BINALOC
в информационном наборе и хочу, чтобы оно возвращало значение из таблицы MLGT при определенных условиях:
- Если поля MLGN-LTKZE и MLGT-LGTYP совпадают, тогда верните связанное поле MLGT-LGPLA.
- Если MLGN-LTKZE = ‘R1’, то возвращается только соответствующий MLGT-LGPLA, где MLGT-LGTYP = ‘006’.
- Если MLGN-LTKZE <> MLGT-LGTYP возвращает пустое значение.
В настоящее время я могу выполнить первые 2 условия, но не могу выполнить третье, поскольку оно конфликтует с числом 2.
Я перепробовал множество инструкций IF и различные порядки для условий IF, а также различные типы соединений.
Это текущий код, который у меня есть в разделе кодирования дополнительных полей BINALOC
:
IF MLGN-LTKZE = 'R1'.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP eq '006'.
ENDSELECT.
else.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP eq MLGN-LTKZE.
endselect.
endif.
Я хочу, чтобы поле возвращало пустое значение, когда поля, о которых я упоминал ранее, не совпадают.
В настоящее время он возвращает копию поля над ним.
Ответ №1:
это?
IF MLGN-LTKZE = 'R1'.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP eq '006'.
ENDSELECT.
else.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP eq MLGN-LTKZE.
endselect.
if sy-subrc ne 0.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP ne MLGN-LTKZE.
endselect.
endif.
endif.
Комментарии:
1. Да, чувак, ты просто находка. Я знал, что это будет что-то довольно простое, я просто новичок в ABAP и не знал, как правильно использовать sy-subrc в этом случае, но этот код имеет смысл. Спасибо за помощь.
Ответ №2:
Прежде всего, на это трудно ответить, потому что 3 функциональных правила могут быть интерпретированы, поскольку они имеют перекрывающиеся условия.
Соответствуют ли они этой таблице истинности:
MLGN-LTKZE Exists MLGN-LTKZE/MLGT-LGTYP BINALOC
---------- ---------------------------- -------------------------------
=R1 true or false MLGT-LGPLA for LGTYP='006'
<>R1 true MLGT-LGPLA for LGTYP=MLGN-LTKZE
<>R1 false blank
Тогда программа должна быть такой:
if MLGN-LTKZE = 'R1'.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP eq '006'.
endselect.
else.
select LGPLA as LGPLA
from *MLGT into BINALOC
where *MLGT~LGTYP eq MLGN-LTKZE.
endselect.
if sy-subrc ne 0.
clear BINALOC.
endif.
endif.
Проблема, с которой вы столкнулись, вероятно, заключается в том, что если одна строка соответствовала третьему условию, то BINALOC не был очищен, и поэтому сохранялось значение, вычисленное во время обработки предыдущей строки.