使用外部表访问oracle告警日志

本文介绍了通过使用oracle外部表的方式访问oracle告警日志。

1、创建用户、赋予权限

SQL>create user checker identified by password default tablespace users quota unlimited on users;

SQL>grant connect,resource,create any directory to checker;

2、创建目录对象

SQL>show parameter background_dump_dest;

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
background_dump_dest                 string      /u01/app/oracle/orcl/bdump

SQL> conn  checker/password

SQL>create directory  bdump as '/u01/app/oracle/orcl/bdump';

3、创建外部表

SQL> create table alert_log( text varchar2(400) )
organization external (type oracle_loader
default directory bdump
access parameters (records delimited by newline)
location('alert_orcl.log'));

4、使用外部表查看告警日志

SQL> select   text   from  alert_log;  //查看全部的告警日志

SQL>select  text  from  alert_log  where  text like 'ORA-%';  //查看告警日志中的错误信息

SQL> select * from (select text from alert_log order by rowid desc) where rownum <50;  //查看最近50行告警日志。

扩展知识:

外部表就像是在数据库中创建的一个视图,数据库中只存储表的元数据,真正的记录存放在操作系统上。对于外部表的使用有一些限制:

1、只能读取外部表中的内容,不能对外部表进行DML操作,不能为其创建索引。

2、使用外部表必须使用目录对象。

3、同一个操作系统数据文件只能使用一种分隔符,如逗号或分号。

4、删除外部表时应遵循先删除所有的外部表然后再删除目录对象的原则,如果直接删除目录对象,系统不会自动检查它上面外部表,可能会造成外部表不可用。可以通过查询dba_external_locations查询系统当前所有的目录对象以及相关的外部表,还会查询出这些外部表所对应的操作系统文件的名字。

 

来源:http://www.chinaoug.net/space.php?uid=356676&do=blog&id=1843

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值