举例场景:创建采购申请的接口中,在执行完BAPI之后返回了一个PR,接着就会执行到commit提交的接口,然如果还需要在创建的时候直接审批,那么就需要再调用PR审批的BAPI。但是你会发现有的PR,在ME23N查看的时候是审批状态,而有的并未审批。
原因:因为程序在执行的时候,也就是commit的时候,还并未提交到数据库中,而后就直接执行了审批的流程。在开发的角度来说,这是同步执行的“后果”。
解决:既然知道了是同步导致的,数据没有及时更新到数据库,那么就可以找到对应的解决办法。
一:在第一次commit之后,使用 WAIT UP TO n SECONDS。等待几秒。
WAIT UP TO 5 SECONDS. 等待5秒
WAIT UP TO '0.5' SECONDS. 等待0.5秒
说明:n为整数或小数,小数需要用单引号引上
二:将同步改为异步需要在接口名称后面加上:STARTING NEW TASK 'strName',也可以配合 WAIT UP TO n SECONDS 使用。
CALL FUNCTION 'ZHY_FM_CRT_APPROVAL' STARTING NEW TASK 'ZAPPROVAL'
EXPORTING
i_prno = prno
tables
et_return = gt_return_approval.