MB51选择屏幕与报表增强
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."当选择屏幕筛选字段有值 SELECTmblnr,
mjahr,
zeile,
znumFROMZTPP001INTO 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'.APPENDmblnr.CLEARmblnr.
mjahr-low = ls_ztpp001-mjahr.
mjahr-sign = 'I'.
mjahr-option = 'EQ'.APPENDmjahr.CLEARmjahr.
zeile-low = ls_ztpp001-zeile.
zeile-sign = 'I'.
zeile-option = 'EQ'.APPENDzeile.CLEARzeile.CLEAR:ls_ztpp001.ENDLOOP."标准表中该字段是空的,并不存值,所以此处要清空, "避免标准代码用此字段筛选查询MSEG表,导致数据为空,所以此处要清空 CLEARznum[].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[].SELECTztpp001~mblnr,
ztpp001~mjahr,
ztpp001~zeile,
ztpp001~ZNUMFROMZTPP001
INNER JOIN @lt_list ASLIST ON ztpp001~mblnr = LIST~MBLNRAND ztpp001~mjahr = LIST~mjahrAND ztpp001~zeile = LIST~zeileINTO TABLE @DATA(LT_ZPP001).SORT LT_ZPP001 BYMBLNR 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,重新生成对应代码
配置的字段就更新进来了
定期更文,
欢迎关注