Почему r_data_line_descr из cl_salv_bs_runtime_info=>get_data_ref() не связана?

У меня есть этот код, который работает очень хорошо в течение нескольких месяцев:

SUBMIT (IV_REPORT_NAME)
   WITH SELECTION-TABLE selection_table
   USING SELECTION-SET IV_SELECTION_SET_VARIANT
AND RETURN.


FIELD-SYMBOLS <lt_data>             TYPE ANY TABLE.
FIELD-SYMBOLS <lt_data_line>        TYPE ANY TABLE.

DATA          lr_data               TYPE REF TO data.
DATA          lr_data_line          TYPE REF TO data.
DATA          lr_data_descr         TYPE REF TO cl_abap_datadescr.
DATA          lr_data_line_descr    TYPE REF TO cl_abap_datadescr.

cl_salv_bs_runtime_info=>get_data_ref(
     IMPORTING r_data_descr      = lr_data_descr
                          r_data_line_descr = lr_data_line_descr ).

IF lr_data_descr IS NOT BOUND.
  ev_result_json = '[]'.
  EXIT.
ENDIF.

....

Но для одного отчета lr_data_descr "НЕ ОБЯЗАН", если вызывается через rfc.

Это работает, если я запускаю функциональный модуль через "тест" в se80. Но если я позвоню через rfc, он не будет связан. Я использую одного и того же пользователя (типа "сервис") для RFC и SE80.

Другими словами: тот же ввод и тот же код. Он работает с обычной отладкой, но не работает (не связан) с удаленной отладкой.

Почему есть разница?

Есть ли способ получить сообщение об ошибке?

Это действительно помогло бы, если бы я мог понять причину, по которой это не связано.

Я отладил в get_data_ref():

Эта строка ведет себя по-другому:

import t_component to lt_component from memory id cl_salv_bs_runtime_info=>c_memid_data_def.
if sy-subrc eq 0.

Если я тестирую функциональный модуль в se80, то sy-subrc равен 0. Если я выполняю внешнюю отладку (тот же пользователь), то sys-subrc 4,

Это специальный отчет. Это имя: AQZZZMM=========ZME80FN=======

1 ответ

Единственный случай, когда r_data_line_descr из cl_salv_bs_runtime_info=>get_data_ref() не связан это:

  • ALV не называется

С запросами SAPquery это происходит, когда данные не извлекаются (в программе запросов переменная %runmode-show_on пусто, когда нет данных, ALV не отображается, см. скриншот ниже).

Итак, ваша проблема, вероятно, из-за значений выбора, переданных вашей программой pyRFC, которые ничего не соответствуют. Когда вы вызываете запрос из SAP, эти значения отличаются и возвращают некоторые данные (проверьте его отладкой, чтобы проверить, какие значения отличаются).

Другие вопросы по тегам