ABAP中的SET UPDATE TASK LOCAL是什么意思?

本文详细解析了SAP系统中的逻辑工作单元(LUW)概念及其注册方式,并通过示例对比了SETUPDATETASKLOCAL关键字的作用,帮助读者理解如何在不同场景下选择合适的更新策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

经常有小伙伴问,看到有些ABAP程序中,在CALL FUNCTION IN UPDATE TASK之前,会加上一步SET UPDATE TASK LOCAL,这个到底是什么意思呢?

1. 基础知识

1.1 SAP LUW

要弄清楚SET UPDATE TASK LOCAL的作用,要先了解SAP LUW这个概念,不知道的小伙伴可以先百度下。简而言之, SAP LUW (logical unit of work) 是一个逻辑业务单元,将属于同一业务单元的数据看做一个整体。在一个SAP LUW内的操作,要么一起成功,要么一起失败。这样可以确保业务逻辑数据的一致性。

注册SAP LUW的方式有下面三种:

Update (bundling using function modules) 
语法:CALL FUNCTION ... IN UPDATE TASK

◾Transactional RFC (bundling using function modules) 
语法:CALL FUNCTION ... IN BACKGROUND UNIT

◾Bundling using subroutines 
语法:PERFORM ... ON COMMIT 

仅当遇到COMMIT WORK关键字是,SAP LUW内注册的内容才会真正的执行。

1.2 Internal Session

一个Session也即一个进程,SAP系统内有三种类型的进程:

  • DIA - 会话进程
  • UPD / UPD2 - 更新进程
  • BTC - 后台进程
  • SPO - Spool Request (处理打印请求)

对于注册与SAP LUW内的请求,通常是通过UPD请求处理的。也即,在会话进程DIA内,用户可能进行了若干的业务操作(例如,更新了某些业务数据),操作结束后,客户点击保存(程序中触发Commit Work),退出会话进程。

此时,从用户的角度,业务已经结束。但实际,在Commit Work触发后,系统后台会触发UPD进程,处理更新操作。

2. SAP LUW举例

下面代码是注册SAP LUW, 并触发Commit Work的一个最简单的实例:

ls_linkage-aapm_guid = cl_system_uuid=>create_uuid_x16_static( ).
CALL FUNCTION 'ZTEST_INSERT_LINKAGE' IN UPDATE TASK
  EXPORTING
    is_linkage = ls_linkage.

COMMIT WORK.
WRITE: 'done.'.

在调试器中,打开Update Debugging 模式,这样我们可以追踪到执行COMMIT WORK后,系统打开的UPD更新进程。
在这里插入图片描述
效果入下:
在DIA进程外,会并行打开一个UPD进程来执行SAP LUW注册的内容。
在这里插入图片描述

3. SET UPDATE TASK LOCAL的作用

了解了以上的基础知识,理解SET UPDATE TASK LOCAL就非常容易啦。其实这组关键字已经很好地表达了其作业,也即 “在本进程中执行更新任务”

示例代码:

SET UPDATE TASK LOCAL.

ls_linkage-aapm_guid = cl_system_uuid=>create_uuid_x16_static( ).
CALL FUNCTION 'ZTEST_INSERT_LINKAGE' IN UPDATE TASK
  EXPORTING
    is_linkage = ls_linkage.

COMMIT WORK.
WRITE: 'done.'.

这段代码和之前代码的区别就在于,在注册LUW前,先声明了SET UPDATE TASK LOCAL.

这样的效果是,在执行COMMIT WORK时,并不会开启新的UPD进程来进行LUW内程序的执行,而是在本DIA进程内,顺序执行LUW的内容。

效果如下:

  • 在注册IN UPDATE TASK时,没有任何区别,仅注册,不执行
  • 遇到Commit Work后,在本session内,执行Function Module 内部的内容
    在这里插入图片描述

4. 小结与对比

相信通过上面的两个小例子,已经清楚地说明了SET UPDATE TASK LOCAL这组关键字的作用。下面是几点小结和对比:

  1. SET UPDATE TASK LOCAL要声明在CALL FUNCTION IN UPDATE TASK前才会其效果
  2. 在使用SET UPDATE TASK LOCAL模式下,COMMIT WORK和COMMIT WORK AND WAIT的效果是一样的(因为顺序执行其实就是在wait 😃 )
  3. SET UPDATE TASK LOCAL模式下只影响high-priority 的Update Function Module, 对于Low-priority 的Function Module是不起作用的,也即low-priority的update function module还是会开启新的UPD进程进行执行
    在这里插入图片描述
    以上便是对于SET UPDATE TASK LOCAL的解读,希望可以解答你的疑问。

本博客专注于技术分享,干货满满,持续更新。 欢迎关注❤️、点赞👍、转发📣!

### ABAP 中实现 BDC 异步更新的方法 在 SAP ABAP 环境下,BDC (Batch Data Communication) 是一种用于模拟用户输入并自动处理大量交易的技术。当涉及到异步更新时,意味着提交的数据不会立即反映到数据库中,而是通过后台作业或其他方式延迟处理。 对于希望实现 BDC 的异步更新操作,在编写 ABAP 代码时可以考虑以下几个方面: #### 使用 `CALL TRANSACTION` 或者 `SUBMIT` 命令配合后台任务调度 为了确保数据能够以异步方式进行更新,可以通过创建一个新的后台作业来运行相应的事务码或程序[^1]。这通常涉及使用函数模块如 `BP_JOB_OPEN`, `BP_JOB_CLOSE` 和 `RSUBMIT_REP_TO_SPOOL_REQUEST` 来管理这些后台作业的生命周期。 下面是一个简单的例子展示如何利用 `SUBMIT` 动态启动另一个报告作为后台进程的一部分,并设置其为异步模式: ```abap DATA: lv_jobname TYPE TJOBN. " 开启新的后台工作 CALL FUNCTION 'BP_JOB_OPEN' EXPORTING job_name = sy-repid " 当前程序名可作为job name * IMPORTING * JOB_NUMBER = EXCEPTIONS OTHERS = 1. IF sy-subrc <> 0. MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno WITH sy-msgv1 INTO DATA(lv_error). ENDIF. TRY. SUBMIT zyour_program TO SESSION AND RETURN USING SELECTION-TABLE it_selopt VIA SELECTION-SCREEN WITHOUT OUTPUT DESTINATION IN GROUP DEFAULT KEEPING ALL PARAMETERS. CATCH CX_ROOT INTO DATA(cx_root). ENDTRY. " 关闭后台工作 CALL FUNCTION 'BP_JOB_CLOSE' EXPORTING job_name = sy-repid EXCEPTIONS OTHERS = 1. IF sy-subrc <> 0. MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno WITH sy-msgv1 INTO lv_error. ENDIF. ``` 需要注意的是上述代码片段中的某些部分可能需要根据具体的应用场景调整,比如传递给子程序的具体参数列表 (`it_selopt`) 及其他配置选项。 另外一个重要概念是在执行过程中控制更新行为。如果想要让被调用的程序在其自己的上下文中独立完成所有的更改而不阻塞主流程,则可以在适当位置加入如下指令以启用本地更新模式[^3]: ```abap SET UPDATE TASK LOCAL. ``` 此命令使得后续发生的任何改变都会在一个单独的任务里被执行直到遇到下一个相同声明之前;因此非常适合用来构建非同步化的业务逻辑分支。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

十年铸器

给作者赏杯咖啡

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值