你好,游客 登录 注册 搜索
背景:
阅读新闻

ORA-04031错误的解决思路

[日期:2012-07-30] 来源:Linux社区  作者:l106439814 [字体: ]

使用ASMM的情况下04031问题很少,但有些应用不合理也会导致内存耗尽.
1.没有使用绑定变量,导致解析资源占用太多
2.打开过多的cursor不释放
3.bug

第一种.
 使用绑定变量
 使用cursor_sharing参数
第二种.
 查找哪个会话打开的游标比较多
 
 SQL> select sid,count(*) from v$open_cursor group by sid order by 2 desc;

 SID   COUNT(*)
----------- ----------
 148     39
 157     25
 149     22
 147     19
 161     16
 154     15
 162      7
 156      7
 152      2
 150      2
 151      1

11 rows selected.

Elapsed: 00:00:00.01
SQL> select SID,USER_NAME,sql_text from v$open_cursor where sid in (148,157);

找出打开游标多的SID执行的什么SQL,再根据业务判断代码位置.去修改代码

第三种
打补丁

linux
相关资讯       Oracle错误日志 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款