sap abap开发从入门到精通_SAP开发-ABAP数据字典(锁)

834d0fc8120e6c583b0c91c4f9a681e4.png

企业级软件或开发框架,必然支持后台高并发,即支持多人同时访问数据库。SAP作为资深企业管理软件,自然也不例外,ABAP可以很方便的开发出支持高并发的程序,要实现高并发,正确使用锁对象是其中一个重要环节,今天我们就一起来看看SAP的锁对象。

SAP锁对象属于数据字典的一部分,它并不是数据库锁,而是存在于队列应用服务器内存中,是一种逻辑锁,假设现在A,B两个用户要同时修改一张表中的记录,为了保证数据一致性,程序先为A用户加锁,加锁成功后,A用户可以正常修改表。这时B用户也要修改此表,程序同样尝试为B用户加锁,但发现表已经被锁定,那么加锁失败,程序需要提示B用户表已被锁定。只有当A用户修改完毕,将锁释放,B用户才可以正常修改表。

SAP锁有多种模式,常用的有E, S, X, O这几种。下面分别做简要说明:

模式E:当更改数据的时候设置为此模式。

模式S:本身不需要更改数据,但是希望显示的数据不被别人更改。

模式X:和E类似,但是不允许累加,完全独占。

模式O:乐观锁,多个用户可以重复加乐观锁,但当有新的用户加了排它锁E,或者已有用户的乐观锁提升为排它锁时,所有的乐观锁将失效。

除了上述几种模式,还要理解锁的拥有者即owner,一般来说,SAP锁要么属于dialog会话进程,要么属于update进程。程序运行是从dialog会话进程开始的,当调用call function...in update task时,会进入update 进程,这个时候update进程会继承锁对象。这两种拥有者的区别在于,如果拥有者是update进程,那么执行commit work后,锁会自动消失。

理解了锁的模式和拥有者,我们来看看在系统中如何创建和使用锁对象。

b3b8a32afca3e37fe87aa06923681a92.png

a4c6d80a1990fee3dfc836fa0ae18018.png

b1c159a46e05cdba1851f3488bce5d90.png

步骤1:事务码SE11,选择所对象,输入EZ_ZTDEPEMP。注意所对象要求必须E 开头。

步骤2:选择锁模式,常用模式上面有介绍过,一般选择E。

步骤3:输入锁参数,默认是表的关键字。输入参数后,可以指定锁定那些记录,如果参数为空,则锁定整张表。保存激活后,锁对象就创建成功了。

那么如何使用这个锁对象呢,SAP锁对象在创建的时候,会额外自动创建两个函数,ENQUEUE_EZ_XXXXX 和 DEQUEUE_EZ_XXXXX。具体到我们刚才创建的锁对象,函数分别是ENQUEUE_EZ_ZTDEPEMP 和 DEQUEUE_EZ_ZTDEPEMP,用于加锁和解锁。在程序中调用这两个函数,然后可以通过事务码SM12观察加锁和解锁的情况。

一起来看一段锁产生冲突的代码:

CALL FUNCTION 'ENQUEUE_EZ_ZTDEPEMP'EXPORTINGmode_ztdepemp  = 'E'mandt          = sy-mandt
*   DEPNO          = '001'
*   EMPNO          = '000001'
*   X_DEPNO        = ' '
*   X_EMPNO        = ' '_scope         = '1'
*   _WAIT          = ' '
*   _COLLECT       = ' 'EXCEPTIONSforeign_lock   = 1system_failure = 2OTHERS         = 3.
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.

打开两个窗口运行这段程序,第一个窗口运行程序后,通过事务码SM12,查看锁对象,

370ecb69a1520f38c700bb53505b4825.png

可以看到表ZTDEPEMP加锁成功了,第二个窗口再次运行程序,会发现没有产生新的锁对象,通过debug,发现sy-subrc = 1,说明表再次加锁和现有的锁冲突了,不应该继续更改表。

上面的程序,有两个重要参数,

mode_ztdepemp = 'E',这个参数就是之前提到的锁模式。E表示更新排它锁。一个用户加E类型锁后,其它用户就不能继续加锁。

_scope = '1',这个参数用来指定锁的拥有者owner。_scope = '1'时,锁的拥有者是dialog会话。_scope = '2'时,当出现CALL FUNCTION 'XXX' IN UPDATE TASK 时,update会话就会继承这个锁,这样在commit work时,锁就会自动释放掉。我们将上面的代码稍作修改,_scope = '2'。再通过debug 和SM12观察锁对象,可以验证上面的锁机制。

CALL FUNCTION 'ENQUEUE_EZ_ZTDEPEMP'EXPORTINGmode_ztdepemp  = 'E'mandt          = sy-mandt
*   DEPNO          = '001'
*   EMPNO          = '000001'
*   X_DEPNO        = ' '
*   X_EMPNO        = ' '_scope         = '2'
*   _WAIT          = ' '
*   _COLLECT       = ' 'EXCEPTIONSforeign_lock   = 1system_failure = 2OTHERS         = 3.
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.CALL FUNCTION 'ZFM_UPDATE_DEPEMP' IN UPDATE TASK.COMMIT WORK.

最后,我们来看看乐观锁的使用。假设现在有两个屏幕都要修改同一张表,如果使用排它锁E,那么只有一个屏幕可以在修改模式下查看数据。如果我们需要多个屏幕都以修改模式来查看,那可以使用乐观锁O。当数据需要保存时,再将乐观锁升级为排它锁。升级的同时,其它的乐观锁都会自动消除。如何使用乐观锁和升级成排它锁,可以参考下面代码。

CALL FUNCTION 'DEQUEUE_EZ_ZTDEPEMP'EXPORTINGmode_ztdepemp = 'O'mandt         = sy-mandt
*   DEPNO         = '001'
*   EMPNO         = '000001'
*   X_DEPNO       = ' '
*   X_EMPNO       = ' '
*   _SCOPE        = '3'
*   _SYNCHRON     = ' '
*   _COLLECT      = ' '.CALL FUNCTION 'ENQUEUE_EZ_ZTDEPEMP'EXPORTINGmode_ztdepemp  = 'R'mandt          = sy-mandt
*   DEPNO          = '001'
*   EMPNO          = '000001'
*   X_DEPNO        = ' '
*   X_EMPNO        = ' '_scope         = '1'
*   _WAIT          = ' '
*   _COLLECT       = ' 'EXCEPTIONSforeign_lock   = 1system_failure = 2OTHERS         = 3.
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.

先将mode_ztdepemp = 'O' 设置为O,即为乐观锁,再将mode_ztdepemp = 'R' 设置为R,升级为排它锁。

SAP锁对象就介绍到这里了,希望大家能不断积累经验,写出更加健壮的程序。如有问题,可加入群讨论。

微信号:eckwise

4bf2b33366a9ad7569f6093b0464e89a.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/337297.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

(acm)C++加速输入的几种方法

点击蓝字关注我们来源于网络&#xff0c;侵删1.CIO流的同步和绑定在C中&#xff0c;cin和cout的速度其实不并不慢&#xff0c;C中的流的IO速度相当的快&#xff0c;其速度与初始设定的缓存区大小和硬盘的IO速度有关。但在C中&#xff0c;为了兼容C的IO(scanf和printf)&#xff…

python引用函数_python 调用函数

Python内置了很多有用的函数&#xff0c;我们可以直接调用。要调用一个函数&#xff0c;需要知道函数的名称和参数&#xff0c;比如求绝对值的函数abs&#xff0c;只有一个参数。可以直接从Python的官方网站查看文档&#xff1a;也可以在交互式命令行通过help(abs)查看abs函数的…

服务器编写_编写下载服务器。 第六部分:描述您发送的内容(内容类型等)...

服务器编写就HTTP而言&#xff0c;客户端下载的只是一堆字节。 但是&#xff0c;客户真的很想知道如何解释这些字节。 它是图像吗&#xff1f; 还是ZIP文件&#xff1f; 本系列的最后一部分描述了如何向客户端提示她下载的内容。 设置 内容类型描述了返回的资源的MIME类型 。 …

python读取xls文件详解_python3解析excel文件

一.需要的依赖 : xlrd二.代码#codingutf-8import xlrd读取Excel每个sheet的第一列和第二列的值,拼接成json串,写入文件def resolveExcel():# 获取excel文件data xlrd.open_workbook("/you/excel/location/?.xlsx",encoding_overrideutf-8)#获取一个excel有多少个sh…

jdbc时区_什么比日期和时区更难? SQL / JDBC中的日期和时区!

jdbc时区在jOOQ邮件列表上&#xff0c;最近有一个有趣的讨论&#xff0c;关于jOOQ当前缺乏对TIMESTAMP WITH TIME ZONE数据类型的现成支持。 没有人说日期&#xff0c;时间和时区很容易&#xff01; 这里有一个有趣的文章&#xff0c;我建议阅读&#xff1a; 虚假的程序员相信…

C语言与C++的区别终于有人说清楚了!

点击蓝字关注我们来源于网络&#xff0c;侵删1、前言在很大程度上&#xff0c;C是C的超集&#xff0c;这意味着一个有效的C程序也是一个有效的C程序。C和C的主要区别是&#xff0c;C支持许多附加特性。但是&#xff0c;C中有许多规则与C稍有不同。这些不同使得C程序作为C程序编…

postgresql两个列模糊比较_数据分析之SQL优化系列(二)---PostgreSQL 的索引

参考《PostgreSQL11.2-中文手册》下面这个链接&#xff0c;讲的通俗易懂&#xff0c;可以看看。数据分析师不得不知道的SQL优化 - 鑫获 - 博客园​www.cnblogs.com索引是提高数据库性能的常用途径。比起没有索引&#xff0c;使用索引可以让数据库服务器更快找到并获取特定行。但…

淘宝客静态单页_单页应用程序的Spring Boot静态Web资源处理

淘宝客静态单页诸如gulp和grunt之类的Javascript构建工具确实让我大吃一惊&#xff0c;我看着这些工具的构建脚本之一&#xff0c;发现很难理解它&#xff0c;并且无法想象从头开始编写其中一个构建脚本。 这就是yeoman出现的地方&#xff0c;它是一种非常方便的工具&#xff0…

高达 36 斤的 C/C++ 编译器?

点击蓝字关注我们来源于网络&#xff0c;侵删前言软件有重量吗&#xff1f;有人说&#xff0c;现代的软件主要搭载在硬件之上&#xff0c;只有占用内存的大小&#xff1b;也有人说&#xff0c;软件都是在网络上下载下来的&#xff0c;哪有什么重量可言&#xff1b;还有人说&…

双屏全屏跳回到主屏_双屏笔记本了解下?剪视频不要太好使

[PConline 评测]每天一开始上班&#xff0c;我们就要开始跟各种电脑程序和窗口打交道&#xff0c;而当面对各种信息和数据的轰炸时&#xff0c;恨不得就要把ALTTAB两个键给磨烂了。↑每天至少要面对十多个窗口gif而今天&#xff0c;笔记本厂商也不再吝啬于给予用户更多更大的屏…

jvm与非jvm语言优劣_都灵JVM编程语言:使用ANTLR构建高级词法分析器

jvm与非jvm语言优劣正如我在上一篇文章中所写的那样&#xff0c;我最近开始研究一种名为Turin的新编程语言。 可以在GitHub上找到适用于languag初始版本的编译器。 我目前正在改善语言&#xff0c;并正在开发Maven和IntelliJ插件。 在这里和下一篇文章中&#xff0c;我将介绍编…

一例看懂C语言程序中的内聚和耦合

点击蓝字关注我们来源自网络&#xff0c;侵删一、原理篇&#xff08;清楚相关原理的读者&#xff0c;请直接看第二部分示例篇&#xff09;在软件工程中&#xff0c;模块的内聚和耦合是度量模块化质量的标准之一。内聚是指模块的功能强度的度量&#xff0c;即一个模块内部各个元…

openfire消息通知推送_APP消息推送功能之前端后台设计

APP消息推送功能之前端后台设计最近有不少小伙伴问APP消息推送功能&#xff0c;前端、后台如何设计的&#xff1f;消息系统的架构是什么样的&#xff1f;最近刚好做到后台消息推送这块&#xff0c;简单谈谈个人心得&#xff0c;欢迎拍砖。消息推送是让自己的用户获取信息最有效…

apache spark_Apache Spark:更改架构之前必须解决的5个陷阱

apache spark迁移到Apache Spark之前需要了解的5件事 似乎每个人都只是在谈论最热门的新技术&#xff0c;而忽略采用它的实际含义。 但这是自然的&#xff0c;对吧&#xff1f; 新功能和承诺胜过其他所有事物&#xff0c;而艰难的挑战和决​​定被抛在一边。 这次不行。 软件…

分步解析C++实现通讯录管理系统

点击蓝字关注我们来源于网络&#xff0c;侵删一、前言建议亲手写一遍代码&#xff0c;感受指针神奇的魅力&#xff1b;可以帮助你更好的巩固知识体系&#xff0c;熟悉指针&#xff0c;结构体与函数一起使用时的妙处完成通讯录管理系统所需知识体系结构体指针函数的封装指针与函…

python代码可以内嵌在asp文件中_在IE中使用Python作为开发脚本(转)

正在学习python&#xff0c;除了语法优美&#xff0c;功能强大外&#xff0c;最看重的是它的可扩展性&#xff0c;可以嵌入到asp和其他一些开发语言中。对IIS配置了.py的扩展名解析&#xff0c;可以对.py的页面进行访问&#xff0c;但asp页面的python脚本仍然无法解析&#xff…

服务器禁止head 请求_编写下载服务器。 第四部分:有效地执行HEAD操作

服务器禁止head 请求HEAD是一个经常被遗忘的HTTP方法&#xff08;动词&#xff09;&#xff0c;其行为类似于GET&#xff0c;但不返回正文。 您使用HEAD来检查资源的存在&#xff08;如果不存在&#xff0c;它应该返回404&#xff09;&#xff0c;并确保您的缓存中没有陈旧的版…

如何用C++实现动态放烟花(附源码)

点击蓝字关注我们来源于网络&#xff0c;侵删一、前言C实现的放烟花程序用到了EGE图形库&#xff0c;没有的需要自行安装可调项&#xff1a;背景图和背景音乐、粒子模糊度、亮度以及上升速度的参数。实现的动态烟花非常好看&#xff0c;可以做给女朋友或者表白用&#xff0c;呵…

java8 streams_Java SE 8新功能介绍:使用Streams API处理集合

java8 streams使用Java SE 8 Streams的代码更干净&#xff0c;易读且功能强大..... 在“ Java SE 8新功能导览”系列的这篇文章中&#xff0c;我们将深入解释并探索代码&#xff0c;以了解如何使用流遍历集合&#xff0c;从集合和数组创建流&#xff0c;聚合流值。 在上一篇文…

nginx哪个版本性能好_nginx性能为什么好

nginx在启动后&#xff0c;在unix系统中会以daemon的方式在后台运行&#xff0c;后台进程包含一个master进程和多个worker进程。我们也可以手动地关掉后台模式&#xff0c;让nginx在前台运行&#xff0c;并且通过配置让nginx取消master进程&#xff0c;从而可以使nginx以单进程…