暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

How to list all events?(oracle事件列表)

原创 Anbob 2012-09-06
485
每个event 都有一个编号对于错误异常,并且同时拥有一个和多个levels
其中有两个编号段比较特殊
1,错误编号-10000到-10999 不是真正的错误,是保留下来用于debug使用
2,错误编号-20000到-20999是自定义异常,错误信息最大2048B
在ORACLE的不同版本中可能有些event已失效,没有在oracle support的情况下不要随便在生产库或开发库上做实验,因为有些事件可以导致数据库 crash
但有时想做某个debug,不记的编号,可以做个列表好搜索
linux/unix下可以通过oerr ora code,列出所有的events,使用Shell 也可以转储到一个文件中

event=10000
while [ $event -ne 10999 ]
do
event=`expr $event + 1`
oerr ora $event
done

登录数据库后也可以用SQLERRM返回

SET SERVEROUTPUT ON
DECLARE
err_msg VARCHAR2(120);
BEGIN
dbms_output.enable (1000000);
FOR err_num IN 10000..10999
LOOP
err_msg := SQLERRM (-err_num);
IF err_msg NOT LIKE '%Message '||err_num||' not found%' THEN
dbms_output.put_line (err_msg);
END IF;
END LOOP;
END;
/

也unix/linux系统下$ORACLE_HOME/rdbms/mesg/oraus.msg 这个文件明文列出了所有的事件
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论