ResultSet内存溢出OutOfMemory问题

错误信息如下:

jdbc在操作oracle海量数据的时候用ResultSet获取所有的返回数据出现内存溢出

处理:
出错的原因是ResultSet用的是可滚动结果集,正常情况下ResultSet是指针指向数据库的数据,本身是不存储数据库的数据的,默认情况下就算是提交的sql能查询处上亿条的数据也是不消耗内存的,但是如果用的是可滚动结果集的ResultSet情况就不一样了,ORACLE 是不支持可滚动结果集的,那么我们用JDBC得到一个可滚动的结果集就是由JDBC自己支持的,也就是说结果集是要存放在内存中的,所以在海量数据的情况下也就是要消耗大量内存的,因此造成内存溢出也就是正常的了,所以如果是海量数据的话就不要用可滚动结果集就可以了。
Java中,ResultSet游标溢出通常是指当ResultSet对象中的数据量较大时,ResultSet对象的游标无法容纳所有数据,因此可能会出现异常。 ResultSet游标在Java中是一个指向ResultSet对象中当前行的指针。当我们使用ResultSet对象从数据库中检索数据时,ResultSet对象会将数据存储在内存中,并使用游标来跟踪当前行。 当ResultSet对象中的数据量很大时,ResultSet对象可能无法容纳所有数据,因此可能会出现游标溢出异常。这种情况通常会发生在以下情况下: 1. 当ResultSet对象中的数据超过了JVM的内存限制时。 2. 当ResultSet对象被关闭时,游标指针无法再次访问ResultSet对象中的数据。 为了避免ResultSet游标溢出异常,可以尝试以下方法: 1. 使用分页查询:如果ResultSet对象中的数据量很大,可以使用分页查询来减少ResultSet对象中的数据量。 2. 使用ResultSet的滚动模式:使用ResultSet的滚动模式可以让ResultSet对象的游标在ResultSet对象中向前或向后滚动,从而避免游标溢出异常。 3. 使用JDBC的fetchSize属性:可以通过设置JDBC的fetchSize属性来控制ResultSet对象中数据的数量,从而避免ResultSet游标溢出异常。 总之,ResultSet游标溢出异常是一个常见的异常,在使用ResultSet对象时需要特别注意。可以通过使用分页查询、滚动模式和设置JDBC的fetchSize属性来避免这种异常的发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值