关于IN UPDATE TASK

更新程序必须用一个特殊的FM(update module)来实现。

 

1.Exporting Exception参数被忽略

UPDATE MODULE和其他的FM一样,有传输参数的接口,但是只能有IMPORTING和TABLES,并且类型只能用参考或者结构,EXPORTING和EXCEPTION参数在UPDATE MODULE里是被忽略的。

 

2.Commit work or Roll back work 时才执行
UPDATE MODULE里包含实际的数据库更新语句。
使用这样写法的FM不会立即执行,而是写进LOG TABLE,作为一个执行请求,一个SAP LUW下的更新请求存储在同一个UPDATE KEY下对一个SAP LUW来说UPDATE KEY是一个唯一的世界范围的识别码,意思就是一个SAP LUW的UPDATE KEY是唯一的,不会和另外的SAP LUW的UPDATE KEY重复 。
只有当程序执行到COMMIT WORK的时候,才会为这些请求创建一个抬头条目LOG HEADER,表示以上这些同样UPDATE KEY的属于同一个包,然后系统关闭这个LUW。
当LOG HEADER创建以后,系统通知DISPATCHER有一个更新包已经准备好可以处理了。

使用例子:

[转载]关于IN <wbr>UPDATE <wbr>TASK


[转载]关于IN <wbr>UPDATE <wbr>TASK

[转载]关于IN <wbr>UPDATE <wbr>TASK


COMMIT WORK [AND WAIT(同步)].
如果使用AND WAIT选项,那么在程序继续执行以前,它要等到更新任务的结束。如果更新是成功的,SY-SUBRC 就设置为0。如果 SY-SUBRC 返回一个非零值,就没有成功的存储所作的更改。
ROLLBACK WORK.
如果对更改的取消是成功的,SY-SUBRC 就设置为0。如果 SY-SUBRC 返回一个非零值,就没有成功地取消所作的更改

 

    CALL FUNCTION 'Z_SAR_UPDATE' IN UPDATE TASK
      EXPORTING
        im_sar_no          wa_sar_hdr-zsar_no
        im_sar_hdr_old     wa_sar_hdr_old
        im_sar_hdr_new     im_sar_hdr
        im_sar_item_old    t_sar_item_old
        im_sar_item_new    im_sar_item
        im_sar_partner_old t_sar_partner_old
        im_sar_partner_new im_sar_partner
        im_sar_status_old  wa_sar_status
        im_sar_retro_old   t_sar_retro_old
        im_sar_retro_new   im_sar_retro.


  COMMIT WORK AND WAIT.

  IF sy-subrc 0.
  ELSE.
    ROLLBACK WORK.
    RAISE update_error.
  ENDIF.

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值