ABAP知识——消息的那些事儿

在学习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用户打赏——赞赏码

你可能感兴趣的:(ABAP知识——消息的那些事儿)