zoukankan      html  css  js  c++  java
  • 关于 IN UPDATE TASK

    【转 http://blog.sina.com.cn/s/blog_6f74e6d50100sq57.html】
    更新程序必须用一个特殊的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.

  • 相关阅读:
    DNN学习笔记代码学习:LogDetailInfo 荣
    DNN学习笔记代码学习:BasePortalException 荣
    DNN学习笔记代码学习:LogInfo 荣
    DNN学习笔记代码学习:ExceptionModule 荣
    DNN学习笔记代码学习:LoggingProvider 荣
    DNN学习笔记代码学习:LogProperties 荣
    DNN学习笔记代码学习:LogController 荣
    DNN学习笔记代码学习:ExceptionLogController 荣
    DNN学习笔记代码学习:LogInfoArray 荣
    DNN学习笔记代码学习:CBO 荣
  • 原文地址:https://www.cnblogs.com/rainysblog/p/4009145.html
Copyright © 2011-2022 走看看