在学习ABAP的过程中,我们一定遇到过以下的疑问:
1、TYPE DISPLAY LIKE究竟是什么意思
2、为什么标准程序提示错误后,就可以编辑字段,而我自己开发的程序就不行?
3、为什么在某个增强点里写的错误消息,会导致程序退出?
4、为什么有的增强里写了消息,却没有提示,或不按我TYPE的方式提示?
本文将介绍我所了解的SAP的消息那些事儿,并解答上述这些疑问。
SAP消息
包括以下类型
A ABORT 中止消息
E ERROR 错误消息
I INFORMATION 对话框消息
S STATUS 常用的提示消息
W WARNING 警告消息
X EXCEPTION 异常消息,通常是DUMP
在SAP的帮助系统中,有关于消息的大量解释,如下图:
(有些版本的消息解释不在此目录下。这时,可以在MESSAGE TYPE的TYPE上按F1,然后再找到Behavior of messages的帮助项)
本来,我也是翻译了所有的这些内容,并整理成表格,但由于很多是我们日常用不到的,所以在这里还是有重点的进行说明吧,也方便大家阅读。
关于TYPE和DISPLAY LIKE
比如TYPE 'S' DISPLAY LIKE 'E',很多人疑问,明明报了错误消息,为什么后续代码还是执行。
真正起作用的是TYPE的类型,DISPLAY LIKE的类型只是显示效果。
PAI中的E、W类型消息
屏幕的PAI包括:
普通屏幕的PAI
选择屏幕的PAI(AT SELECTION-SCREEN)。
PAI中的代码内容包括:
普通代码
VALUE-REQUEST(以下简称POV)
HELP-REQUEST(以下简称POH)
EXIT COMMAND的代码(以下简称FUNCTION-E)
普通屏幕PAI-普通代码
界面影响
如果在CHAIN中的FIELD模块中输出,则只有当前FIELD可被编辑;如果在CHAIN中输出,则CHAIN中所有的FIELD可被编辑
程序影响
PAI中断,返回到当前屏幕而不触发PBO(对于W类型,回车后,程序恢复执行)
选择屏幕PAI-普通代码
界面影响
选择屏幕字段可被编辑
程序影响
选择屏幕PAI中断,返回选择屏幕而不触发选择屏幕的OUTPUT事件(对于W类型,回车后,程序恢复执行)
普通屏幕PAI-其他代码,或选择屏幕PAI-其他代码
界面影响
显示异常界面(DUMP)
程序影响
不允许在POH、POV、FUNCTION-E中输出E和W消息,触发未处理的异常
这样,我们的第二个问题就有了答案。要想让普通屏幕的字段可以在报错时被编辑,就要在FIELD后的MODULE中或者FIELD所在的CHAIN的MODULE中进行错误提示。
PBO中的消息
不管是普通屏幕的PBO,还是选择屏幕的AT SELECTION-SCREEN OUTPUT,都只能显示三种消息类型,即A、S、X。对于另外三种,E、I、W,则会进行消息类型的转化,如下:
E-->A
I-->S
W-->S
也就是说,PBO中的E错误消息,会转为A类型,导致程序中止。
更新模式中的错误处理
非本地更新
除S类型外,其他消息类型都会导致更新中止,数据库回滚。
本地更新
S和X以外的消息,都会转为A类型。A类型的结果就是出现中止对话框,更新中止,数据库回滚。而X类型的消息会DUMP。
(本地更新用SET UPDATE TASK LOCAL打开。具体的意义请参见F1或百度)
这就解释了第三个问题。在有些增强点里提示错误消息,却导致程序退出,就是增强点代码位于更新模块中,因为消息的E类型会被转化为A类型。
函数调用时的消息处理
标准程序中,有很多增强点是这样写的
(看到Exceptions error_message = 1了吗)
以上图为例,该函数执行时,就会截获函数中的消息,并且不显示出来,而是通过函数后面的代码,判断SUBRC,当有错误消息时,用I类型的方式显示。
这样,我们的第四个问题也有了答案。如果消息没有显示出来,或者没有按自己希望的方式显示出来,请检查一下它所在的函数被调用时,是不是加上了类似的代码。
有关其他方面的消息处理,比如LIST PROCESSING、批处理、后台JOB、转换例程、RFC等,还是请大家F1慢慢了解吧。
IOS/ANDROID用户打赏——赞赏码