1、文档说明

如之前文档《MIGO新增页签增强》,在MIGO中增强自定义字段,那么在查询MB51时,想通过自定义字段进行筛选,并将数据展示到报表中,就需要对MB51进行增强。

此处需要说明,文档《MIGO新增页签增强》中是将自定义字段存入自建表中,读者也可以自己研究,是否能将字段存入标准表MSEG中。两种做法不同,则在本篇文档中的做法也有一定区别,请读者予以辨别。

2、增强实施

2.1、增强字段

文档《MIGO新增页签增强》中将MIGO增强字段存储在表ZTPP001中

因为需要将数据展示在报表中,所以要在标准表中增强字段

MSEG

MATDOC

此处请注意,如果增强的字段和MIGO中增强的字段名称一致,则需要修改MIGO增强页签中的一段逻辑

文档《MIGO新增页签增强》中在增强方法IF_EX_MB_MIGO_BADI~POST_DOCUMENT中,将MIGO增强的字段存表时,为了得到物料凭证、年度、行项目的值,曾使用MOVE-CORRESPONDING,将MSEG结构的数据传递到自建表的内表中。如果MSEG增强字段和ZTPP001字段名一致,就会使ZTPP001的ZNUM被MSEG的ZNUM(空值)覆盖掉,所以此处可以单独将物料凭证、年度、行项目赋值给ZTPP001的内表。当然,读者也可以定义不一样的字段名,避免覆盖的情况。

2.2、配置选择屏幕

可以通过配置,为MB51新增筛选和展示字段

TCODE:SPRO

新增对应字段,其中选择字段:显示在选择屏幕中,输出字段:显示在报表中

保存之后,重新执行MB51,标准代码则自动更新,此时单据号字段就显示在选择屏幕上

查看包含文件RM07DOCS_GENERATED,可以看到代码更新的时间

选择屏幕代码中也已经自动添加了ZNUM

2.3、隐式增强

在RM07DOCS_GENERATED的子例程FORM DATA_SELECTION_NEW开头位置创建隐式增强

代码如下

"--------------------@斌将军--------------------
IF sy-tcode = 'MB51'.
IF znum[] IS NOT INITIAL."当选择屏幕筛选字段有值
SELECT
mblnr,
mjahr,
zeile,
znum
FROM ZTPP001
INTO TABLE @DATA(lt_ztpp001)
WHERE znum IN @znum.
"将物料凭证、年度、行项目赋值到对应的筛选字段中
LOOP AT lt_ztpp001 INTO DATA(ls_ztpp001).
mblnr-low = ls_ztpp001-mblnr.
mblnr-sign = 'I'.
mblnr-option = 'EQ'.
APPEND mblnr.
CLEAR mblnr.
mjahr-low = ls_ztpp001-mjahr.
mjahr-sign = 'I'.
mjahr-option = 'EQ'.
APPEND mjahr.
CLEAR mjahr.
zeile-low = ls_ztpp001-zeile.
zeile-sign = 'I'.
zeile-option = 'EQ'.
APPEND zeile.
CLEAR zeile.
CLEAR:ls_ztpp001.
ENDLOOP.
"标准表中该字段是空的,并不存值,所以此处要清空,
"避免标准代码用此字段筛选查询MSEG表,导致数据为空,所以此处要清空
CLEAR znum[].
ENDIF.
ENDIF.
"--------------------@斌将军--------------------

同样的代码,增强到以下子例程的开头处

FORM DATA_SELECTION

FORM DATA_SELECTION_VIA_MATNR

FORM DATA_SELECTION_VIA_BUDAT

在RM07DOCS的FORM detail_list中创建隐式增强,将数据赋值到ALV中

代码如下

"--------------------@斌将军--------------------
ENHANCEMENT 5 ZEMM_MB51_APPEND. "active version
IF list[] IS NOT INITIAL.
DATA(lt_list) = list[]. SELECT
ztpp001~mblnr,
ztpp001~mjahr,
ztpp001~zeile,
ztpp001~ZNUM
FROM ZTPP001
INNER JOIN @lt_list AS LIST ON ztpp001~mblnr = LIST~MBLNR
AND ztpp001~mjahr = LIST~mjahr
AND ztpp001~zeile = LIST~zeile
INTO TABLE @DATA(LT_ZPP001). SORT LT_ZPP001 BY MBLNR MJAHR ZEILE. LOOP AT list ASSIGNING FIELD-SYMBOL(<fs_list>).
READ TABLE LT_ZPP001 INTO DATA(LS_ZPP001) WITH KEY mblnr = <fs_list>-MBLNR
mjahr = <fs_list>-mjahr
zeile = <fs_list>-zeile BINARY SEARCH.
IF SY-SUBRC EQ 0.
<fs_list>-ZNUM = LS_ZPP001-ZNUM.
ENDIF.
ENDLOOP. ENDIF.
ENDENHANCEMENT.
"--------------------@斌将军--------------------

2.4、测试效果

输入单据号

数据表中存储的数据

运行结果

2.5、问题说明

此方法实现的屏幕筛选,并不能像常规一样,多个筛选条件取交集,而是与其他筛选字段取并集。读者可以根据项目情况,灵活更改代码实现需求。

3、MB51代码重置

正常情况下,如上文中配置完屏幕字段后,运行MB51,对应的MB51源码就能更新。但是也存在个例,运行MB51时,源代码没有更新过来,选择屏幕中并没有对应的字段

推测原因,可能是开发的增强与MB51要更新的代码出现了冲突,导致更新失败。

例如:有的选择屏幕字段,是直接增强上去的,而不是配置的,导致配置的字段与原本增强的字段重复,所以更新失败

解决方法一:

注释选择屏幕中自开发的增强字段和相关的增强,然后运行MB51,保证程序不DUMP的情况下,程序就会自动再更新源码

解决方法二:

如果仍然不能更新,则采用以下办法,根据官方提供的程序,手动执行更新

首先注释与选择屏幕相关的自开发增强逻辑,保证源码被重置时,使用到选择屏幕等字段的逻辑不报错,保证MB51的正常运行

找到官方NOTE:

根据官方源码,创建并执行程序

对比前后的RM07DOCS_GENERATED,可以发现选择屏幕等源代码全部都没了

执行事务代码MB51,重新生成对应代码

配置的字段就更新进来了

定期更文,欢迎关注

MB51选择屏幕与报表增强的更多相关文章

  1. ALV报表——选择屏幕选项卡

    ALV选择屏幕选项卡 运行效果: 代码: *&--------------------------------------------------------------------* *&a ...

  2. ALV报表——选择屏幕变量赋值

    ABAP选择屏幕变量赋值 运行效果: 代码: *&---------------------------------------------------------------------* ...

  3. 选择屏幕(Selection Screen)

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  4. abap 选择屏幕事件AT SELECTION-SCREEN

    AT SELECTION-SCREEN (1).其实就像一个FORM,所以在这个事件里声明的变量都是局部变量. (2).根据SY-UCOMM这个系统变量可以判断用户的命令 (3).在这个事件里响应的是 ...

  5. [SAP ABAP开发技术总结]动态修改选择屏幕

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  6. [SAP ABAP开发技术总结]选择屏幕——按钮、单选复选框

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  7. [SAP ABAP开发技术总结]选择屏幕——SELECT-OPTIONS

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  8. 选择屏幕中的下拉框和dialog中下拉框设计

    REPORT  YTEST014. PARAMETERS: auart LIKE vapma-auart  AS LISTBOX   VISIBLE LENGTH 6. AT SELECTION-SC ...

  9. abap选择屏幕上的button

    1.背景:近期在看sap的一些abapDemo,看了一个比較好用的功能.分享一下.希望对用到的兄弟有帮助,主要功能是:在选择屏幕上弹出一个小窗体.放一些button在上面,触发不同button,会处理 ...

  10. 【ABAP系列】SAP ABAP选择屏幕(SELECTION SCREEN)事件解析

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP选择屏幕(SEL ...

随机推荐

  1. NET8 ORM 使用AOT SqlSugar

    AOT介绍 .Net8的本地预编机器码AOT,它几乎进行了100%的自举.微软为了摆脱C++的钳制,做了很多努力.也就是代码几乎是用C#重写,包括了虚拟机,GC,内存模型等等.而需要C++做的,也就仅 ...

  2. Calendar日历类型常见方法(必看!!)

    Hi i,m JinXiang 前言 本篇文章主要介绍Calendar日历类型的几种常见方法以及部分理论知识 欢迎点赞  收藏 留言评论 私信必回哟 博主收将持续更新学习记录获,友友们有任何问题可以在 ...

  3. 如何配置CentOS 7网络

    不久之前在配置CentOS 7网络,记录一下操作过程. CentOS 7,你可以按照以下步骤配置网络: 打开终端,输入命令查看本台服务器的IP信息. ip a 输入命令查看网关. ip r 输入命令查 ...

  4. 嵌入式linux主机通过分区镜像生成固件,DD备份分区后打包成固件,px30刷机教程 ,rockchip刷机教程

    我这边有一个工控路由器因为刷机变砖了,网上下载不到固件,自己暂时还没有搞过编译.我找到了同型号的路由器,把它的系统制作成镜像. 具体操作分为三步: 第一步,直接用DD命令备份了几个分区,分区我暂时还不 ...

  5. classpath 和 classpath* 的区别

    classpath 和 classpath* 的区别 classpath 和 classpath* 是两种不同的类路径搜索模式,它们在寻找资源文件时有所不同: classpath:classpath ...

  6. java中C3P0、Druid、HikariCP 、DBCP连接池的jar包下载与IDEA配置

    ## 一.什么是连接池连接池是应用程序与数据库之间的一个缓冲区,它存储了一定数量的空闲数据库连接,当应用程序需要连接数据库时,可以从连接池中获取一个可用连接,使用完毕后再将连接归还给连接池,从而避免了 ...

  7. python数据类型元组、列表、集合、字典相互嵌套

    系统 Windows 10 专业工作站版22H2 软件 python-3.9.6-amd64.exe 拓展库: jupyter==1.0.0 notebook==7.0.6 1.元组嵌套 1.1 元组 ...

  8. macOS 苹果电脑双面打印单面打印PDF设置

    苹果的打印服务分为两个部分,一个是应用层另一个是系统层. 其中双面打印或单面打印统一在系统层面设置,下面我分别截图示意wps pdf和福昕pdf两款软件设置双面打印. 1.WPS PDF 在完成方式中 ...

  9. Mongodb安装篇+可视化工具篇

    下载MongoDB 官网下载地址:Download MongoDB Community Server | MongoDB   Version 选择:稳定版4.4.2 Mongo的版本分为稳定版和开发版 ...

  10. Windows下使用C#和32feet.NET开发蓝牙传输功能的记录

    引用的第三方Nuget库 32feet.NET 3.5.0 MaterialDesignColors MaterialDesignThemes Newtonsoft.Json 使用到的技术: XAML ...