首页 > 其他分享 >SAP中的COMMIT WORK 与 ROLLBACK WORK

SAP中的COMMIT WORK 与 ROLLBACK WORK

时间:2024-03-15 11:03:44浏览次数:22  
标签:BAPI TRANSACTION ROLLBACK 数据库 WORK COMMIT

文章目录

数据库中的COMMIT和ROLLBACK

COMMIT WORK

使用COMMIT WORK语句后,对数据库的更改将不能取消。

COMMIT WORK AND WAIT

用COMMIT WORK AND WAIT语句,在等待数据库里的数据更新完成后,在进行下一步操作,数据频繁更新的时候,或者对下一步代码数据有影响的时候,用COMMIT WORK AND WAIT比COMMIT WORK更加的安全可靠。

ROLLBACK WORK

使用ROLLBACK WORK语句取消前一次对数据库提交后的更改。

案例分享

在更新数据库时,ROLLBACK WORK.和COMMIT WORK.的使用

  DATA: LCX_ERROR TYPE REF TO CX_ROOT. "cx_sy_sql_error . "cx_sy_open_sql_db.
  DATA ERR_TEXT TYPE C LENGTH 1000.
     
  TRY."需要做出判断,防止程序出错
      INSERT [数据库表] FROM TABLE [内表]. "往数据库里插入数据
    CATCH CX_SY_OPEN_SQL_DB INTO LCX_ERROR.
      ERR_TEXT = LCX_ERROR->GET_TEXT( ). "得到错误信息
      SY-SUBRC = 4. "改变系统变量
  ENDTRY.

  IF SY-SUBRC <> 0.
    ROLLBACK WORK.
    MESSAGE '数据更新失败!' && ERR_TEXT TYPE 'E'.
  ELSE.
    COMMIT WORK.
    MESSAGE '数据更新成功!' TYPE 'S'.
  ENDIF.

先使用CATCH语句判断数据是否更新成功,成功时使用COMMIT WORK语句,使数据库的更改变成不可修改,失败时,使用ROLLBACK WORK语句取消先前对数据库更改的影响。

BAPI中的COMMIT和ROLLBACK

BAPI_TRANSACTION_COMMIT

使用BAPI的时候,操作成功的时候,要使用BAPI_TRANSACTION_COMMIT函数使BAPI生效.

CALL FUNCTION 'BAPI_TRANSACTION_COMMIT'
		EXPORTING
		wait = 'X'.  

其中同步时,多个BAPI不间断的调用,之间可能互相影响操作结果(资源调用导致另一个BAPI操作失败),所以BAPI_TRANSACTION_COMMIT函数要给wait参数赋值’X’。

BAPI_TRANSACTION_ROLLBACK

操作失败的时候用BAPI_TRANSACTION_ROLLBACK使BAPI无效。

CALL FUNCTION 'BAPI_TRANSACTION_ROLLBACK'.  

标签:BAPI,TRANSACTION,ROLLBACK,数据库,WORK,COMMIT
From: https://blog.csdn.net/m0_45846097/article/details/136729250

相关文章

  • 猫头虎分享已解决Bug || 网络攻击(Network Attack):DDoSError, NetworkIntrusion
    博主猫头虎的技术世界......
  • 猫头虎分享已解决Bug | org.springframework.dao.DuplicateKeyException异常的正确解
    博主猫头虎的技术世界......
  • 在VMware Workstation pro16 中安装Red Hat Enterprise 8时屏幕屏幕缩小,无法继续。
    情况说明:1.在vm里设置自由拉伸2.不等待,回车选中。3.避免点击“添加磁盘”done......
  • 孪生网络(Siamese Network)和数字孪生的区别?
    1.孪生网络孪生网络是一种特殊的网络框架,基于两个人工神经网络建立的耦合构架,通过比较两个样本在高维度空间的表征来判断它们的相似程度。它包含两个相同结构的神经网络,一个用于学习,一个用于验证学习效果。在训练过程中,两个网络同步更新参数,但验证网络的参数更新较慢,这有......
  • Adaptive Diffusion in Graph Neural Networks论文阅读笔记
    AdaptiveDiffusioninGraphNeuralNetworks论文阅读笔记Abstract​ 最近提出了图扩散卷积(GDC),利用广义图扩散来扩展传播邻域。然而,GDC中的邻域大小是通过在验证集上进行网格搜索来手动对每个图进行调整的,这使得其泛化实际上受到了限制。为了解决这个问题,我们提出了自适应扩散......
  • 【Django进阶】djangorestframework-jwt使用
    【Django进阶】djangorestframework-jwt使用  简介Jsonwebtoken(JWT),是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。JWT的声明一般被用来在身份提供者和服务提供者......
  • Django REST Framework(DRF)
    DjangoRESTFramework(DRF) 前言:DjangoRESTframework,是1个基于Django搭建 REST风格API的框架,简称DRF。1、什么是API呢?API就是访问即可获取数据的url地址,下面是一个最简单的DjangoAPI,访问http://127.0.0.1:8000/,返回用户列表;fromdjango.conf.urlsimporturlfrom......
  • VMware workstation新建虚拟机网络使用NAT模式的各个问题
    使用Vmwareworkstation创建linux(centos7)虚拟机时,在网络方面可能会碰到各种问题:1.重启后网络就断了,没法开机自启动2.如何配置固定IP3.ping不通www.baidu.com...问题1:重启后网络就断了,没法开机自启动解决:修改配置文件,一般是:/etc/sysconfig/network-scripts/ifcfg-e......
  • Be Your Own Teacher: Improve thePerformance of Convolutional Neural Networks via
    摘要本文中,提出了一种名为自蒸馏的通用训练框架,该框架通过缩小网络的规模而不是扩大网络的规模,而提高卷积神经网络的性能。传统的知识蒸馏是一种网络之间的知识转换方法,它迫使学生神经网络接近预先训练的教师神经网络的softmax层输出,与此不同,所提出的自蒸馏框架提取网络......
  • Android Framework基础知识
    哈喽大家好,我是Zzz.给大家分享一篇Framework入门的基础知识文章,内容纯纯原创。一、Application,Activity和进程的关系?  Application、Activity只是进程虚拟机运行的一个类对象,只是属于系统的一个组件和进程没有直接联系。Android支持为每个组件可以单独进程方式运行。 ......