使用功能模块更新BSEG-ZUONR



我成功地用FM CHANGE_DOCUMENT更改了BKPF-BKTXT,但为什么我不能用FM CHANGE_DOCUMENT更改BSEG-ZUONR呢?

这是FM CHANGE_DOCUMENT:

CALL FUNCTION 'CHANGE_DOCUMENT'
  TABLES
    T_BKDF           = t_bkdf
    T_BKPF           = t_bkpf
    T_BSEC           = t_bsec
    T_BSED           = t_bsed
    T_BSEG           = t_bseg
    T_BSET           = t_bset
*   T_BSEG_ADD       =
          .

以下是更改BKPF-BKTXT(成功)的代码:

wa_t_bkpf-mandt = sy-mandt.
wa_t_bkpf-bukrs = '1000'.
wa_t_bkpf-gjahr = gjahr_import.
wa_t_bkpf-belnr = belnr_import.
wa_t_bkpf-bktxt = zuonr_import.
APPEND wa_t_bkpf TO t_bkpf.

以下是更改BSEG-ZUONR(失败)的代码:

wa_t_bseg-mandt = sy-mandt.
wa_t_bseg-bukrs = '1000'.
wa_t_bseg-gjahr = gjahr_import.
wa_t_bseg-belnr = belnr_import.
wa_t_bseg-buzei = '1'.
wa_t_bseg-zuonr = zuonr_import.
APPEND wa_t_bseg TO t_bseg.

由于作者没有时间确认,我可以为他做这件事,因为我刚刚测试了这个案例。如果我们将其签名中的所有参数传递给FM,更新将顺利运行。例如,像这样:

DATA: lt_bkdf TYPE TABLE OF bkdf,
      lt_bkpf TYPE TABLE OF bkpf,
      wa_bkpf TYPE bkpf,
      lt_bsec TYPE TABLE OF bsec,
      wa_bseg  TYPE bseg,
      lt_bsed TYPE TABLE OF bsed,
      lt_bseg TYPE TABLE OF bseg,
      lt_bset TYPE TABLE OF bset.
wa_bkpf-mandt = sy-mandt.
wa_bkpf-bukrs = '5900'.
wa_bkpf-gjahr = gjahr_import.
wa_bkpf-belnr = belnr_import.
wa_bkpf-bktxt = 'Batch'.
APPEND wa_bkpf TO lt_bkpf.
wa_bseg-mandt = sy-mandt.
wa_bseg-bukrs = '5900'.
wa_bseg-gjahr = gjahr_import.
wa_bseg-belnr = belnr_import.
wa_bseg-buzei = '1'.
wa_bseg-zuonr = '20151131'.
APPEND wa_bseg TO lt_bseg.
  CALL FUNCTION 'CHANGE_DOCUMENT'
    TABLES
      t_bkdf           = lt_bkdf
      t_bkpf           = lt_bkpf
      t_bsec           = lt_bsec
      t_bsed           = lt_bsed
      t_bseg           = lt_bseg
      t_bset           = lt_bset
      .
COMMIT WORK.

除最后一个参数外,所有FM表参数都是强制性的。

请勿使用此FM

CALL FUNCTION 'CHANGE_DOCUMENT' 

FM正在将所有其他字段更改为初始字段(如果未提供)。


CALL FUNCTION 'FI_DOCUMENT_CHANGE'

FM似乎无法用于更改具有帐户类型(BSEG-KOART)-"S"(总账帐户)的行项目。


试试这个FM:

'FI_ITEMS_MASS_CHANGE'
字段zuonr引用它所属的对象。例如采购订单。

让asume你支付一个采购订单的位置。bkpf/bseg中的文档已创建(以及更多)。Bseg Zuonr包含此采购订单位置的编号。

如果允许更改此字段,则会破坏数据的引用完整性。它会指向一个不是从中创建的采购订单位置,或者一个根本不存在的位置。

因此,从业务角度来看,在创建该字段后更改它是没有意义的,因此SAP永远不允许更改它。

相关内容

  • 没有找到相关文章