大尾巴 2017-09-19 02:47 采纳率: 100%
浏览 1393
已采纳

oracle数据库执行存储过程内存使用量问题

最近在使用存储过程处理大批量数据,里面用到了游标,在进行测试的时候报错“ORA-20000:ORU-10027:BUFFER OVERFLOW, LIMIT OF 10000 BYTES”。
从网上查询是数据量太多了,用DBMS_OUTPUT.ENABLE(BUFFER=>NULL)可以解除内存使用限制,但是这样数据量过大的话就会有将数据库服务器内存耗尽的风险。
从这点可以看出,带有游标的存储过程(或者说所有的存储过程无论是用到游标的还是没有用到游标的)是将数据全部查出来放到内存里,然后再对数据进行处理?
有什么办法可以实现内存的重复利用,就是查出来一部分数据处理一部分数据,然后再取一部分数据,处理一部分数据,类似于分页处理一样的。

  • 写回答

1条回答 默认 最新

      报告相同问题?

      相关推荐 更多相似问题

      悬赏问题

      • ¥15 结构体数组文件读取问题
      • ¥15 写c++代码,第7题说一下使用的计算方法
      • ¥15 postman接口自动化测试报告实践总结
      • ¥15 有关c++的问题,利用相关知识
      • ¥15 求香农编码和解码的matlab代码
      • ¥20 ROS中的TEB局部规划问题
      • ¥20 关于#matlab#的问题:要求测出上面图片中所有同心圆的半径
      • ¥20 epanet软件运行问题
      • ¥15 Python 文件读取
      • ¥60 dpabi进行Alff计算时脑池有干扰信号