在SAP中使用SM30记录增删改的修改日志

在SAP中记录使用SM30修改表记录时,对操作登记日志。日志的操作类型分增加、删除、修改。

最后对日志做个报表进行查询。

步骤一、对表设置为表维护生成器(函数组需要新创建)

步骤二、对表添加事件:01事件类型(在数据库中保存数据前),并填写事件方法名称(我这里为CHANGE_ENTRY)

步骤三、点击以上的‘编辑器’,进入编辑代码。需要选择‘插入’

按操作类型<ACTION> = 'D'."删除、<action> = 'U'."修改、<ACTION> = 'N'."新建分别编辑代码。注意删除类型的前一句代码READ TABLE extract WITH KEY <vim_xtotal_key>.是查不到时表示删除在界面中删除了。

具体代码如下:

其中 ZFPACCTXT_LOG为我创建的日志表、ZFPACCTXT为需要在SM30维护的数据表(拷贝以下代码时需要替换这两个表名)

DEFINE assign_field.
  ASSIGN COMPONENT &1 OF STRUCTURE <ls_maintview> TO <lv_field>.
  IF sy-subrc = 0.
    IF <lv_field> IS ASSIGNED.
      <lv_field> = &2.
    ENDIF.
  ENDIF.
END-OF-DEFINITION.

FORM change_entry.
  DATA:WA_LOG_TXT LIKE ZFPACCTXT_LOG.
  DATA:IT_LOG_TXT LIKE TABLE OF ZFPACCTXT_LOG.

  DATA:WA_LOG_NUM LIKE ZFPACCNUM_LOG.
  DATA:IT_LOG_NUM LIKE TABLE OF ZFPACCNUM_LOG.

  DATA:lo_data  TYPE REF TO data,
        lv_tabix TYPE sy-tabix.

  FIELD-SYMBOLS:
    <ls_maintview> TYPE any,
    <lv_field>     TYPE any.

  IF x_header-maintview IS NOT INITIAL.
    CREATE DATA lo_data TYPE (x_header-maintview).
    IF lo_data IS BOUND.
      ASSIGN lo_data->* TO <ls_maintview>.
    ENDIF.
    IF <ls_maintview> IS ASSIGNED.


        IF x_header-maintview = 'ZFPACCTXT'.
          LOOP AT total.
           READ TABLE extract WITH KEY <vim_xtotal_key>.
           IF sy-subrc <> 0.
             IF <ACTION> = 'D'."删除
               MOVE-CORRESPONDING <vim_total_struc> TO WA_LOG_TXT.
               WA_LOG_TXT-OPTY = 'DEL'.
               WA_LOG_TXT-CREATE_DATE = SY-DATUM.
               WA_LOG_TXT-CREATE_TIME = SY-UZEIT.
               WA_LOG_TXT-CREATE_USER = SY-UNAME.
               APPEND WA_LOG_TXT TO IT_LOG_TXT.
            ENDIF.
           ELSE.
              IF <action> = 'U'."修改
               MOVE-CORRESPONDING <vim_total_struc> TO WA_LOG_TXT.
               WA_LOG_TXT-OPTY = 'UPD'.
               WA_LOG_TXT-CREATE_DATE = SY-DATUM.
               WA_LOG_TXT-CREATE_TIME = SY-UZEIT.
               WA_LOG_TXT-CREATE_USER = SY-UNAME.
               APPEND WA_LOG_TXT TO IT_LOG_TXT.
              ENDIF.
              IF <ACTION> = 'N'."新建
                 MOVE-CORRESPONDING <vim_total_struc> TO WA_LOG_TXT.
                 WA_LOG_TXT-OPTY = 'ADD'.
                 WA_LOG_TXT-CREATE_DATE = SY-DATUM.
                 WA_LOG_TXT-CREATE_TIME = SY-UZEIT.
                 WA_LOG_TXT-CREATE_USER = SY-UNAME.
                 APPEND WA_LOG_TXT TO IT_LOG_TXT.
              ENDIF.
            ENDIF.
         ENDLOOP.
        ENDIF.

      
    ENDIF.
  ENDIF.

  IF IT_LOG_TXT[] IS NOT INITIAL.
    MODIFY ZFPACCTXT_LOG FROM TABLE IT_LOG_TXT.
    IF SY-SUBRC = 0.
      COMMIT WORK AND WAIT.
    ELSE.
      ROLLBACK WORK.
    ENDIF.
  ENDIF.

  sy-subrc = 0.

ENDFORM.

到此已经完成日志记录,当在SM30修改、增加、删除数据表 ZFPACCTXT时,会记录日志到日志表中 ZFPACCTXT_LOG。日志查询报表不再做展示了哈

  • 24
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

被挤的奶牛

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值