ABAP BDC 常见问题 -FICO
BDC 在 FICO 模块是经常⽤到的,⽤于批量过账程序时使⽤的,但是稳定性不如使⽤BAPI 的好,但是 BDC 可以有多种 T-CODE 进⾏过账,也有不同的模式,功能也不错,但是在写程序或者是出现问题的时候需要考虑下⾯⼏个问题:
1、可以在程序加⼊BDC 的模式选择,默认为 N 模式,但是可以选择 A 模式,⽅便调试。当然这个也可以 debug 进去之后进⾏改值。
2、LOOP⾥⾯有 CALL BDC 的情况,在每⼀次 CALL TRANSACTION 之后,可以适当延时⼏秒,可以防⽌在有些 t-code 过账的时候出现利润中心被锁着的情况:
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⾥⾯,提取凭证号:
其中,L_BDCMSG-MSGV1 就是返回的凭证号!
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 会有问题。)
评论