How to list all events?(oracle事件列表)_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1716 | 回复: 0   主题: How to list all events?(oracle事件列表)        下一篇 
张伟
注册用户
等级:列兵
经验:110
发帖:81
精华:0
注册:2011-12-22
状态:离线
发送短消息息给张伟 加好友    发送短消息息给张伟 发消息
发表于: IP:您无权察看 2014-12-25 11:14:42 | [全部帖] [楼主帖] 楼主

每个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 这个文件明文列出了所有的事件。

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论