我正在尝试BUT051
使用功能模块更新数据库表BUR_BUPR_BUT051_COLLECT
。
问题是它根本不更新。
这是我目前用于更新的代码的一部分BUT051
。注意:我要更新的字段是BUT051~PARTNER1
.
FORM update_but051.
"--------------------------------------------------------------------"
" TABLES
"--------------------------------------------------------------------"
DATA: lt_but051 TYPE TABLE OF but051.
"--------------------------------------------------------------------"
" STRUCTURES
"--------------------------------------------------------------------"
DATA: ls_but051 TYPE but051.
REFRESH: lt_but051.
CLEAR: ls_but051.
" Getting all relationships of the given accounts/partners
SELECT * FROM but051 INTO TABLE lt_but051 WHERE partner1 IN lt_partners_so.
" Replacing all partners(field `partner1`) with the master partner.
ls_but051-partner1 = p_mstcln.
MODIFY lt_but051 FROM ls_but051 TRANSPORTING partner1 WHERE partner1 <> p_mstcln.
CLEAR: ls_but051.
LOOP AT lt_but051 INTO ls_but051.
CALL FUNCTION 'BUR_BUPR_BUT051_COLLECT'
EXPORTING
i_subname = 'BUT051'
i_but051 = ls_but051.
ENDLOOP.
CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
EXPORTING
wait = abap_true.
ENDFORM.
Run Code Online (Sandbox Code Playgroud)
关于此代码的几点说明:
p_mstcln
是一个类型的参数c(10)
,这是新的合作伙伴编号。lt_partners_so
是一个合作伙伴表,所有这些都需要用p_mstcln
in替换but051
。我是否使用了正确的功能?
是否有其他功能模块,做我想(更新场什么partner1
的but051
)?
BUT051 是业务合作伙伴关系表,SAP 对此有特别说明:
建议使用以下功能模块来更新关系: