美文网首页想法简友广场SAP
SAP小技巧 打造全新的配置体系(二 实现方式)

SAP小技巧 打造全新的配置体系(二 实现方式)

作者: syjf1976_abap | 来源:发表于2021-10-27 16:44 被阅读0次

    点击蓝字 关注我们

    前言

    标准配置体系中都是使用事务代码SM30维护配置表内容. 相对于事务代码SE16N,SM30维护界面过于简陋.无法提供更好的用户体验,尤其是维护数据量较大的时候,用户体验将非常糟糕

    本文主要介绍怎么把SIMGH与SE16N结合,打造成一个全新的配置体系

    感谢曾经的关键用户,现在的公众号群里的活跃用户郝同学对本文的贡献

    实现效果

    在配置树节点点击执行图标后, 进入表的SE16N维护界面

    SIMGH使用方式详见链接无峰,公众号:ABAP开发技巧SAP小技巧之 建立你自己的SPRO

    程序准备

    创建程序ZBC_CONF及对应TCODE: ZBC_CONF

    这个程序用于SIMGH中配置的TCODE调用打开特定表的SE16N编辑

    程序中通过两种方式识别SIMGH传递表内容

    • 包含表名的事务代码,命名规范 ZCONF_<表名>

    • 参数ID CUO 传递的表名

    程序逻辑非常简单.核心逻辑是调用标准函数 SE16N_START

    文末有源代码, 想偷懒的同学可以直接复制

    通过TCODE识别表名的示例:使用ZBC_CONF程序直接创建事务代码ZCONF_ZTIF002. 执行事务代码会直接进入ZTIF002的SE16N维护界面

    配置树维护报错

    使用SIMGH配置实施指南活动

    在配置IMG实施指南活动时,如果输入的定制对象没有维护对象(通过SE11创建的维护对象).系统会显示如下消息. "指定现有定制对象"

    重要字段

    定制对象

    一般输入表或者维护视图

    • 输入表时 后续类型选择 T 或 S

    • 输入维护视图 后续类型选择 V

    类型

    • C 视图簇

    • L 逻辑传输对象

    • S 表 (带文本表格): 类型设置为S时. 后面可以输入用户的事务代码

    • T 单个事务对象

    • V 视图

    • D 名义对象

    解决维护对象报错的方式

    • 方式一:使用通用的维护对象ZTCONF_DEMO,通过TCODE命名识别具体的表名

    • 方式二:手工写入表 OBJH/OBJS/TADR 相关记录.

    • 方式三:使用通用的维护对象ZTCONF_DEMO,TCODE : ZBC_CONF后修改表内容CUS_ACTOBJ

    01

    方式一

    创建一个配置表ZTCONF_DEMO. 为它创建定制对象

    在配置IMG实施指南活动时,使用通用配置对象ZTCONF_DEMO.使用包含表名信息的TCODE 跳转.事务代码调用程序ZBC_CONF

    02

    方式二

    手工写入表 OBJH/OBJS/TADR 相关记录.跳过系统检查.

    如果上述表记录维护不完整,系统会报错

    新增这些表记录的代码可以写在函数CTO_OBJECT_GET函数开头的隐式增强中自动写入.

    维护结果如下图

    03

    方式三

    使用通用对象 ZTCONF_DEMO 和事务代码 ZBC_CONF维护好实施指南对象后. 修改表CUS_ACTOBJ中的内容. 把ZTCONF_DEMO修改为特定的表.

    该表中对象名称字段是关键字, 只能通过新增记录,删除记录的方式修改对象内容

    实现原理

    标准SIMGH 在点击节点执行按钮时,会执行到如下代码, 把定制对象放入参数ID CUO中. 同时调用配置的TCODE.

    调用的TCODE 都指向程序ZBC_CONF. 在程序中通过参数ID或者TCODE 识别表名后,调用SE16N_START进入表的SE16N维护界面.

    批量迁移

    既然新的配置体系有维护方便的优势,怎么批量把旧的配置体系迁移到新的配置体系?

    迁移方式很简单. 把表CUS_ACTOBJ中特定定制活动的内容调整即可.(实测方案可行)

    如下图:

    删除记录 ZTIF002_C  V  ZVIF002_N  SM30

    新增记录 ZVIF002_C  S  ZTIF002      ZBC_CONF 

    SE16N改造

    SE16N可以非常方便的进行单表的维护操作: 新增,修改,删除,传输. 数据过滤,排序等等操作. 对SE16N改造后. 可以实现更多的功能:

    • 增强的全删功能

    • 数据变更文档

    • 配置SE16N授权体系: 通过SE16N的授权配置,还可以实现对配置树的授权.

    • 配置字段的关键字描述(码表)显示

    • 配置字段的隐藏,只读属性

    • 配置关联字段内容显示

    • 配置字段默认值

    • 配置字段检验

    • 配置日期范围间隔校验

    • 配置启用ZTBC001A中的校验

    • ......

    SE16N改造系列是一系列介绍SE16N改造的文章. 让SE16N事务代码拥有更多实用功能. 有兴趣的读者可以在公众号中菜单中找到这些文章.

    详见链接

    无峰,公众号:ABAP 技巧与实战SAP小技巧之 改造SE16N(四)

    SE16N新增功能及可配置功能示意图

    授权配置

    字段属性配置

    字段检验配置

    总结

    通过SIMGH与SE16N的结合,可以快速构建出全新的配置树体系. 相比于原本的SM30维护配置表内容,启用SE16N维护配置表可以让表内容的维护更加方便. 但是还需要解决数据新增/修改/删除写入传入请求的问题. 该问题解决之前, SE16N维护的配置只能手工传输(还存在删除的对象可能无法传输的风险).

    ZBC_CONF是一个很简单的程序,在新的配置体系中打通了SIMGH与SE16N的连接. 这个程序也可以用于快速生成一个表维护的TCODE

    *&---------------------------------------------------------------------**& Report ZBC_CONF*&---------------------------------------------------------------------**&单表通用维护程序:整合表,,SE16N_START*创建TCODE 时,按照 ZCONF_<表名>命名.程序从TCODE中解析表名.*&---------------------------------------------------------------------*REPORT zbc_conf.PARAMETERS: p_tab TYPE tabname DEFAULT '' NO-DISPLAY.INITIALIZATION.*标准IMG执行时在程序 LS_CUS_ACTIVITYF01 472 行左右 会调用预定义的事务代码并通过PARAMETER ID 'CUO' 传递配置对象*      SET PARAMETER ID 'CUO' FIELD objectname.*      CALL FUNCTION 'SPROJECT_BUFFER_NOTE'.*      CALL TRANSACTION p_tcode.  IF sy-tcode = 'ZBC_CONF'.    DATA: lv_objectname TYPE ob_object.    GET PARAMETER ID 'CUO' FIELD lv_objectname.    IF lv_objectname IS NOT INITIAL.      p_tab = lv_objectname .    ENDIF.  ELSE.    SPLIT sy-tcode AT '_' INTO DATA(lv_1) DATA(lv_2).    SELECT SINGLE * FROM dd02l INTO @DATA(ls_dd02l) WHERE tabname = @lv_2.    IF sy-subrc = 0.      p_tab = lv_2.    ENDIF.  ENDIF.START-OF-SELECTION.  CALL FUNCTION 'SE16N_START'    EXPORTING      i_tab          = p_tab*     I_DISPLAY      = ' '*     I_EXIT_SELFIELD_FB       = ' '      i_single_table = 'X' "表名字段不允许输入*     I_HANA         = '

    相关文章

      网友评论

        本文标题:SAP小技巧 打造全新的配置体系(二 实现方式)

        本文链接:https://www.haomeiwen.com/subject/mwdjaltx.html