使用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,再根据业务判断代码位置.去修改代码
第三种
打补丁
,
