SAP Fiori里两种锁机制(lock)的实现
其实标题有点不够准确,ETAG 从严格意义上讲并不是用来锁住一个资源,而是用来避免同一个资源同时被更新造成的彼此覆盖的问题(mid-air collisions
)。
方法1: ETAG 机制
SAP CRM Fiori采用了这种机制。
看一个具体的例子来理解。假设我用用户名Jerry选中了这个ID为3456的Opportunity,点击Edit按钮之后:
会触发一个读操作发到后台:
后台响应这个读请求,并且在响应的头部字段ETAG里写入了对应的值。
这个26AE结尾的ETAG的值可以由应用程序采取不同的逻辑计算,可以直接采用请求节点对应的最后修改时间戳(Last Changed Timestamp), 例如下面这段ABAP代码:
也可以基于数据的完整内容计算一个HASH值出来作为ETAG返回给Fiori UI:
现在我用另一个用户,对同一个Opportunity做了修改,成功保存。然后再回到用户Jerry的这个编辑窗口,此时Jerry根本不知道该Opportunity已经被另一个用户修改了。Jerry修改了Opportunity的Name字段,点击保存按钮。
收到这个提示信息。
从Chrome Development Tool里能观察到,当Jerry点击了保存按钮后,发送到后台的请求的头部包含了一个If-Match字段,这个字段的值就是Jerry第一次点击编辑按钮时,后台返回给Jerry的26AE结尾的ETAG字段。
背后发生了什么事请呢?在框架的方法CHECK_BEFORE_MODIFICATION里,框架会把Fiori UI请求传进来的ETAG和当前最新的ETAG做比较:
CHECK_BEFORE_MODIFICATION又会调用CHECK_ETAG_MATCH方法。如果check失败,当前的保存操作将不会执行。
方法2: 基于BOPF的锁实现
这种方式用于S/4HANA的Fiori应用,比如Material application。这种Fiori应用,消费的OData service是基于CDS view 加上BOPF实现的。
打开一个Material,点击Edit:
此时到ABAP后台使用事务码SM12能观察到Material对应的数据库表被锁住了:
这是怎么实现的呢?
在S/4HANA后台使用事务码BOBX打开BO模型I_PRODUCTWD. 展开模型,双击EDIT,能看到这个Edit实现的类为CL_I_DR_PRODUCTWD.
双击这个class,它的方法LOCK_ACTIVE_DOCUMENT就是响应Fiori UI上编辑按钮点击的处理函数。
我们在这个方法里设置断点,然后在UI上点击编辑按钮,断点触发。从调用栈即可清除观察到编辑按钮点击之后,程序执行流是如何从BOPF框架投递到Material应用的枷锁代码。这个加锁逻辑调用的是传统的ABAP Enqueue function module。
要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:
相关文章
- 数据透视表上线!如何在纯前端实现这个强大的数据分析功能?
- SAP UI5 sap.ui.core.Element 的概要介绍
- SAP UI5 sap.ui.layout.Grid 控件概述
- SAP 电商云 Spartacus UI 的 Product Category Navigation UI 实现
- 关于 SAP UI5 设备类型检测的实现原理
- SAP UI5 sap.ui.Device.media 公有方法介绍
- SAP UI5 sap.ui.Device.media.initRangeSet 方法的单步调试
- 如何使用 SAP UI5 V2 ODataModel 模型 API 实现 deepCreate 的场景以及局限性
- SAP系统升级,如何做数据迁移?
- 关于微软 Edge 浏览器无法访问笔者 SAP UI5 教程示例代码的问题
- 澄清一些对 SAP UI5 响应式表格 sap.m.Table 的常见理解误区试读版
- SAP UI5 响应式表格 sap.m.Table 根据不同宽度的屏幕动态决定显示或隐藏 Column 的实现源代码讲解试读版
- 关于 SAP UI5 应用 render2 实例异步创建的编码实现
- SAP ABAP 报表几个事件的先后执行顺序和作用
- SAP 使用较频繁的日期时间处理函数总结详解编程语言
- SAP标准采购报表增强(包含ME2L ME28 ME2N)详解编程语言
- MM SAP报错整理详解编程语言
- SAP 系统的配置传输 同/异服务器之间,TR请求传输详解编程语言
- SAP MM批次管理(4)批次分类–大海详解编程语言
- SAP–用BAPI-实现销售订单修改-Cond-Value详解编程语言
- SAP SHD0的详细简介详解编程语言
- 比较:Oracle与SAP的对比(oracle和sap)
- SAP发布REST/HTTP接口详解编程语言
- 缓存使用SAP创建Redis缓存,实现高效稳定加速(sap如何创建redis)
- 比拼Oracle与SAP的优劣对比(oracle与sap优劣)
- 使用Oracle与SAP进行数据接口开发(oracle sap接口)