SAP中的COMMIT WORK 与 ROLLBACK WORK

数据库中的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'.  
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值