【DB笔试面试672】在Oracle中,errorstack的作用是什么?
16lz
2021-04-15
♣
题目 部分
如何查找或监控效率低下的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笔试面试850】在Oracle中,造成错误“ORA-12547: TNS:lost con
- 【DB笔试面试851】在Oracle中,造成“ORA-28040: No matching ...
- 调用CXF框架的webservie restful风格服务报415错误的解决方法
- 【MySQL】有关登录连接的几个参数(max_connections等)及其相关错误
- 【转载】 MySQL数据库“十宗罪”(十大经典错误案例)
- Go 开发关键技术指南 | Go 面向失败编程 (内含超全知识大图)
- 【Linux】虚拟磁盘挂载错误,不能进入系统(fsck.ext3:no such file
- ORA-01578和ORA-26040--NOLOGGING操作引起的坏块-错误解释和解决
- 造成错误“ORA-12547: TNS:lost contact”的常见原因有哪些?