如何查找或监控效率低下的SQL语句?在Oracle中,errorstack的作用是什么?
在使用Oracle数据库的过程中,可能会遇到各种各样的错误或异常,而且这些错误或异常的提示并不具体,那么这个时候就可以使用Oracle提供的一种对于错误堆栈进行跟踪的方法即errorstack。通过设置跟踪可以将一些错误的后台信息详尽地转储出来,写入跟踪文件,对于错误的研究与诊断非常有效。
设置errorstack主要有4个级别:
l 0 仅转储错误堆栈(0级已经被逐渐废弃)
l 1 转储错误堆栈和函数调用堆栈
l 2 Level1 + ProcessState
l 3 Level2 + Context area(显示所有游标,着重显示当前游标)
errorstack可以在实例级或会话级别设置,也可以在参数文件中设置,这个设置仅当某个特定的错误出现时才被触发,如设置ORA-01438事件的跟踪:
1alter system set events '1438 trace name errorstack forever,level 3';--启用
2...执行SQL语句...
3alter system set events '1438 trace name errorstack off';--关闭
接下来在告警日志中找到相关的跟踪文件,对该文件进行分析即可。
& 说明:
有关errorstack的更多内容可以参考我的BLOG:http://blog.itpub.net/26736162/viewspace-2136457/。
本文选自《Oracle程序员面试笔试宝典》,作者:小麦苗
---------------优质麦课------------
详细内容可以添加麦老师微信或QQ私聊。