【DB笔试面试672】在Oracle中,errorstack的作用是什么?
作者:互联网
♣
题目 部分
如何查找或监控效率低下的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';--关闭
接下来在告警日志中找到相关的跟踪文件,对该文件进行分析即可。
标签:错误,DB,672,Oracle,转储,设置,errorstack,堆栈 来源: https://blog.51cto.com/lhrbest/2707344