ORA 04031 经典错误
当尝试在共享池分配大块连续的内存失败,很多时候是由于碎片过多,而并非真是内存不足
产生原因:
1)SQL 没有足够的共享
2)大量不必要的解析调用
3)没有使用绑定变量
4)使用flush shared pool 缓解共享池问题
alter system flush shared_pool;
alter session set cursor_sharing=force;
init.ora 中参数对SGA 的大小最有影响;
·JAVA_POOL_SIZL——控制Java 池的大小
·SHARED_POOL_SIZE——把共享池的大小控制在某种程度上
·LARGE_POOL_SIZE——控制大池的大小
·DB_BLOCK_BUFFERS——控制块的缓冲区高速缓存的大小
·LOG_BUFFER——把重做缓冲器的大小控制在某种程度上