matinal:ABAP BDC常见问题

2023-10-14 14:01:36 浏览数 (1)

BDC 在 FICO 模块是经常⽤到的,⽤于批量过账程序时使⽤的,但是稳定性不如使⽤BAPI 的好,但是 BDC 可以有多种 T-CODE 进⾏过账,也有不同的模式,功能也不错,但是在写程序或者是出现问题的时候需要考虑下⾯⼏个问题:

1、可以在程序加⼊BDC 的模式选择,默认为 N 模式,但是可以选择 A 模式,⽅便调试。当然这个也可以 debug 进去之后进⾏改值。


2、LOOP⾥⾯有 CALL BDC 的情况,在每⼀次 CALL TRANSACTION 之后,可以适当延时⼏秒,可以防⽌在有些 t-code 过账的时候出现利润中心被锁着的情况:

代码语言:javascript复制
CALL TRANSACTION 'F-30' USING BDCDATA 
                        MODE P_MODE 
                        MESSAGES INTO L_BDCMSG.
WAIT UP TO p_wait SECONDS.

有时候,当你直接跑,过账失败,⽽你 debug 跑的话就成功,也可以看看是不是锁的问题,然后也可以考虑下对两次⽣成凭证进⾏延时。


3、可能会出现的 A 模式下过账成功,N 模式过账不成功:

原因是:有些是你的 BDC 在这⼀屏没有这个字段,然后会返回⼀个这个字段不存在的 S 类型的 message,然后 BDC 退出了,就没有完全成功过账。

同⼀个屏幕,不同的过账码 科⽬可能有不同的字段。所以录屏完写程序的时候,这个光标的问题,最好还是要有 if 判断或者是基本排除光标,这个基本没有⽤。


4、LOOP⾥⾯过账完,要记得清 BDCDATA,和 BDCMESSAGE


5、过账完了,⽣产的 message⾥⾯,提取凭证号:

代码语言:javascript复制
LOOP AT L_BDCMSG.
  CALL FUNCTION 'MESSAGE_TEXT_BUILD'
    EXPORTING
      msgid = L_BDCMSG-MSGID
      msgnr = L_BDCMSG-MSGNR
      msgv1 = L_BDCMSG-MSGV1
      msgv2 = L_BDCMSG-MSGV2
      msgv3 = L_BDCMSG-MSGV3
      msgv4 = L_BDCMSG-MSGV4
    IMPORTING
      message_text_output = WA_LOG-MSG.

6、遇见 BDC 程序跑了,报错了,最好跑 A 模式去查看报错处在哪个环节了!


7、⼀个 FB60 的 BDC 程序,有些成功并返回了凭证号,有些成功⽣成了凭证号,但是没有返回 message。

原因:这种问题通常是⼀些增强导致。

⽅法:在 S   F5  312 message 前⾯设断点,然后跑 N 模式,查看没有返回凭证号的情况,是在前⾯那⾥跳出了⽽没有跑这个 312 的 message。通常都是增强导致。(遇到⼀个是增强⾥⾯的更新表,然后 commit work 的时候直接跳出了,但是实际表已经更新成功了。因为 modify 是不需要 commit work 的。因为通过 call transaction FB60 的话,⾥⾯有个选项 opt,通过这个选项可以选择执⾏commit work 是否跳出。这也就是为什么 FB60 直接跑这段,即使有 commit work 也没有问题,但是通过 call transaction 会有问题。)

0 人点赞