Как вернуть значение, когда поля не совпадают в информационном наборе SAP

#abap #sap-query

#abap #sap-запрос

Вопрос:

У меня есть основная таблица EKPO, присоединенная к таблицам MLGN и MLGT в качестве внешних соединений.

Я создал дополнительное поле BINALOC в информационном наборе и хочу, чтобы оно возвращало значение из таблицы MLGT при определенных условиях:

  1. Если поля MLGN-LTKZE и MLGT-LGTYP совпадают, тогда верните связанное поле MLGT-LGPLA.
  2. Если MLGN-LTKZE = ‘R1’, то возвращается только соответствующий MLGT-LGPLA, где MLGT-LGTYP = ‘006’.
  3. Если 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 не был очищен, и поэтому сохранялось значение, вычисленное во время обработки предыдущей строки.