abap 可配置通用报表字段级日志监控

server/2024/11/14 0:36:25/

文章目录

    • 1.功能需求描述
      • 1.1 功能
      • 1.2 效果展示
    • 2.数据库表解释
      • 2.1 表介绍
    • 3.数据库表及字段
      • 3.1.应用日志数据库抬头表:ZLOG_TAB_H
      • 3.2.应用日志数据库明细表:ZLOG_TAB_P
      • 3.3.应用日志维护字段配置表:ZLOG_TAB_F
    • 4.日志封装类
    • 5.代码
    • 6.调用方式代码
    • 7.调用案例程序demo

1.功能需求描述

1.1 功能

尽可能的的满足各种报表开发,几乎可以在任何报表中使用该应用日志.
可配置化的应用日志管理,根据用户需求来自定义记录.
使用类封装的方式实现日志收集.
通过事务码或者程序名对报表的某个字段进行日志监控.
通过配置某个报表中的某个字段就可以实现该字段的日志监控
优点:灵活性高,实用性强,
缺点:必须插入代码,无法做到配置好之后就可监控.

1.2 效果展示

举个例子:事务码 ZLOG01 配置了3 个字段分别是 采购凭证H,采购项目P ,金额U. 这个时候在记录日志的时候明细表中就会存在一条某采购凭证下的采购项目中的金额做了修改 ,修改前金额88 修改后金额99.
log.csdnimg.cn/direct/27ce3694961940989eb517cd64af1edd.png" alt="在这里插入图片描述">

2.数据库表解释

2.1 表介绍

创建三张表,分别是抬头,明细,配置表.然后用类进行封装,使用函数模块也可以.
这个类需要把报表中的旧内表和修改后的内表传进去,还要把修改的是那一行的下标穿进去,需要注意的是修改前后的内表数据顺序要保持一致,不然会出现记录的日志数据出错的.
抬头:主要存储事务码,用户信息和日期时间
明细:组要存储以上信息之外还要存储用户日志的记录,要记录用户的字段,字段描述,修改前后的数据以及修改的那个凭证的那个项目的记录.这里的主键以UUID为主.
配置表:该表的主键是事务码和字段,相关描述以及记录表示:D不记录 P项目 H单号 U记录.
整体的思路以上.

3.数据库表及字段

3.1.应用日志数据库抬头表:ZLOG_TAB_H

log.csdnimg.cn/direct/acc7fb43f9aa437690e4eabc6f95d515.png" alt="在这里插入图片描述">

3.2.应用日志数据库明细表:ZLOG_TAB_P

log.csdnimg.cn/direct/5b7e4077e37247da86c82723ccf74c49.png" alt="在这里插入图片描述">

3.3.应用日志维护字段配置表:ZLOG_TAB_F

log.csdnimg.cn/direct/c43b401f14e2405a84244bc34895c34d.png" alt="在这里插入图片描述">

4.日志封装类

log.csdnimg.cn/direct/6e3db23aad1a4e8982ea47fd793389d6.png" alt="在这里插入图片描述">
参数 注意 IT_TABIX 这个参数 他的结构要用指定的ZLOG_S这个结构.
log.csdnimg.cn/direct/35b9a701b31c4aa382b1ccc16a939b31.png" alt="在这里插入图片描述">
应用日志导入结构:ZLOG_S
其他只可以不用传,但这个参数必须传ZINDEX
log.csdnimg.cn/direct/bc27616bde224c97a070b2944481aba5.png" alt="在这里插入图片描述">

5.代码

METHOD create_appl_log.DATA: lv_zdnzj  TYPE zclient VALUE IS INITIAL,ls_header TYPE zlog_tab_h VALUE IS INITIAL,ls_item   TYPE zlog_tab_p VALUE IS INITIAL,lt_item   TYPE TABLE OF zlog_tab_p,lt_field  TYPE TABLE OF zlog_tab_f,ls_field  TYPE zlog_tab_f,ls_tabix  TYPE zlog_s,le_msg    TYPE REF TO cx_sy_assign_error .DATA:lv_new_name TYPE c LENGTH 18,lv_old_name TYPE c LENGTH 18,lv_p TYPE c LENGTH 18,lv_h TYPE c LENGTH 18 .FIELD-SYMBOLS:<fs_old>   TYPE ANY,<fs_new> TYPE ANY,<fs_new_vlue> TYPE ANY,<fs_old_vlue> TYPE ANY,<fs_p> TYPE ANY
logExtensionBox" style="width:400px;margin:auto;margin-top:12px" class="blog-extension-box">

http://www.ppmy.cn/server/141296.html

相关文章

HTML5和CSS3的进阶_HTML5和CSS3的新增特性

目录 HTML5的新特性 1. HTML5 的新特性 1.1 HTML5 新增的语义化标签 1.2 HTML5 新增的多媒体标签 1. 视频 2. 音频 3. 多媒体标签总结 1.3 HTML5 新增的 input 类型 1.4 HTML5 新增的表单属性 required 必须输入信息&#xff0c;不能为空&#xff1b; 重点&#xf…

基础网络安全知识

1.ctfhub技能树 1.1 Web-SQL注入 Web-SQL注入-整数型 && 字符型 && MySQL结构 参考&#xff1a;5.9.6MySql注入 Web-SQL注入-报错注入 step1: 查库名 ?id1 and extractvalue(1,concat(0x7e,database(),0x7e))-- step2: 查看表名 ?id1 and extractvalue(1…

传输协议设计与牧村摆动(Makimoto‘s Wave)

有一条活鱼和一条死鱼&#xff0c;你准备怎么做&#xff0c;你会将活鱼红烧或将死鱼清蒸吗&#xff1f;好的食材只需要最简单的烹饪&#xff0c;不好的食材才需要花活儿。 我此前的文字几乎都在阐述一个观点&#xff0c;广域网就是那条死鱼&#xff0c;数据中心则是那条活鱼。…

Vue 与 React 前端框架差异对比及案例分析

一、设计理念 1.Vue&#xff1a; Vue 被设计为渐进式框架&#xff0c;能够自底向上逐层应用。这意味着可以将其灵活地应用于现有项目的一部分&#xff0c;无需对整个项目进行大规模重构。强调数据驱动视图&#xff0c;通过响应式数据绑定&#xff0c;当数据发生变化时&#x…

服务器数据恢复—分区结构被破坏的reiserfs文件系统数据恢复案例

服务器数据恢复环境&#xff1a; 一台服务器中有一组由4块SAS硬盘组建的RAID5阵列&#xff0c;上层安装linux操作系统统。分区结构&#xff1a;boot分区LVM卷swap分区&#xff08;按照顺序&#xff09;&#xff0c;LVM卷中划分了一个reiserfs文件系统作为根分区。 服务器故障…

c语言编程题(函数)

1编写函数将一个仅包含整数&#xff08;可能为负&#xff09;的字符串转换为对应的整数 方法一使用标准库函数 atoi atoi 函数是C语言标准库中的一个函数&#xff0c;用于将字符串转换为整数。 代码&#xff1a; #include <stdio.h> #include <stdlib.h> // 包含…

一篇Spring Boot 笔记

一、Spring Boot 简介 Spring Boot 是一个用于创建独立的、基于 Spring 的生产级应用程序的框架。它简化了 Spring 应用的初始搭建和开发过程&#xff0c;通过自动配置等功能&#xff0c;让开发者能够快速地构建应用&#xff0c;减少了大量的样板代码和复杂的配置。 二、核心特…

华为:hcia综合实验

一、拓扑图 二、实验要求 1. pc地址请自行规划&#xff0c;vlan已给出 2. 服务器地址自行规划&#xff0c;vlan&#xff0c;网段已给出 3. 交换机互联链路捆绑保证冗余性 4. 内网pc网关集中于核心交换机&#xff0c;交换机vlan 40互联路由器 ,地址网段已给出 5.配置静态路由实…