MySQL的JDBC OutOfMemoryError: Java heap space异常

MySQL的JDBC OutOfMemoryError: Java heap space异常

MySql数据库通过JDBC对大表进行查询时抛出java.lang.OutOfMemoryError: Java heap space异常。这是因为默认情况下,MySQL的JDBC驱动会一下子把所有row都读取下来,这在一般情况下是最优的,因为可以减少Client-Server的通信开销。但是这样也有一个问题,当数据库查询结果很大时,特别当不能全部放进内存时,就会产生性能问题。

本来,JDBC api里在Connection、Statement和ResultSet上都有设置fetchSize的方法,但是MySQL的JDBC驱动都不支持,无论你怎么设fetchSize,ResultSet都会一次性从Server读取数据。在MySQL的官方论坛上也有多个这样的问题,总结一下解决办法如下:

1.MySQL版本在5.0以上,MySQL的JDBC驱动更新到最新版本(至少5.0以上)
2.Statement一定是TYPE_FORWARD_ONLY的,并发级别是CONCUR_READ_ONLY(即创建Statement的默认参数)
3.以下两句语句选一即可:
1).statement.setFetchSize(Integer.MIN_VALUE);
2).((com.mysql.jdbc.Statement)stat).enableStreamingResults();

这样会一行一行地从Server读取数据,因此通信开销很大,但内存问题可以解决。官方的说法是不支持fetchSize不是MySQL的JDBC驱动的问题,而是MySQL本身就不支持。而商用数据库Oracle或DB2都是支持fetchSize的,从这里也可以看出两者的考量不同。

考虑到应用程序利用JDBC跨数据库的特性可以,通过判断mySql连接特殊处理:

if(conn.getClass().getName().indexOf("mysql")>0){

//com.mysql.jdbc.Driver
stmt.setFetchSize(Integer.MIN_VALUE);
}

开始以为是自己的代码有问题,找了半天没找到。后来仔细看了异常才发现:

严重: Servlet.service() for servlet ExportServlet threw exception
java.lang.OutOfMemoryError: Java heap space

at com.mysql.jdbc.Buffer.getBytes(Buffer.java:198)

at com.mysql.jdbc.Buffer.readLenByteArray(Buffer.java:318)
at com.mysql.jdbc.MysqlIO.nextRow(MysqlIO.java:1366)
at com.mysql.jdbc.MysqlIO.readSingleRowSet(MysqlIO.java:2333)
at com.mysql.jdbc.MysqlIO.getResultSet(MysqlIO.java:435)
at com.mysql.jdbc.MysqlIO.readResultsForQueryOrUpdate(MysqlIO.java:2040)
at com.mysql.jdbc.MysqlIO.readAllResults(MysqlIO.java:1443)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1777)
at com.mysql.jdbc.Connection.execSQL(Connection.java:3249)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1268)
at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1403)
at com.mchange.v2.c3p0.impl.NewProxyPreparedStatement.executeQuery(NewProxyPreparedStatement.java:76)
at com.cdnlog.servlet.ExportServlet.doPost(ExportServlet.java:77)

ExportServlet.java:77,代码这里是rs=pstmt.executeQuery();

这句话报错。然后求助网友鬼精灵,找到如上那篇文章。解决了~

谢谢鬼精灵~,哈哈,也许你看不到


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java heap space是一种常见的OutOfMemoryError错误,它表示Java堆内存不足。当Java应用程序需要分配更多的内存给对象,但是堆内存已经被完全使用时,就会抛出这个错误。 解决Java heap space错误的方法有以下几种: 1. 增加堆内存大小:可以通过在启动应用程序时使用-Xmx参数来增加堆内存的大小。例如,使用命令`java -Xmx2g MyApp`将堆内存大小设置为2GB。 2. 优化代码和内存使用:检查代码中是否存在内存泄漏或者不必要的对象引用。确保及时释放不再使用的对象,避免创建过多的临时对象。 3. 使用垃圾回收器:Java提供了不同的垃圾回收器,可以根据应用程序的需求选择合适的垃圾回收器。例如,使用G1垃圾回收器可以更好地处理大内存和多核处理器的情况。 4. 分析内存使用情况:使用工具如VisualVM或JConsole来监视和分析应用程序的内存使用情况,找出内存使用过多的地方,并进行优化。 5. 减少对象的创建和销毁:避免频繁地创建和销毁对象,可以使用对象池或缓存来重复使用对象,减少内存的使用。 6. 使用更高效的数据结构和算法:选择合适的数据结构和算法可以减少内存的使用。例如,使用HashMap代替ArrayList可以减少内存的占用。 范例:<<引用:java.lang.OutOfMemoryError: Java heap space。主要有3种比较常见的OutOfMemory Error: Java.lang.OutOfMemoryError: Java heap space java.lang.OutOfMemoryError: PermGen space java.lang.OutOfMemoryError: GC overhead limit exceeded 。 引用:java.lang.OutOfMemoryError: Java heap space。3. java.lang.OutOfMemoryError: GC overhead limit exceeded 。 请回答我或者给我介绍或演示一下:OutOfMemoryErrorJava heap space? 当Java应用程序需要分配更多的内存给对象,但是堆内存已经被完全使用时,就会抛出Java heap space错误。解决这个错误的方法包括增加堆内存大小、优化代码和内存使用、使用垃圾回收器、分析内存使用情况、减少对象的创建和销毁以及使用更高效的数据结构和算法。具体的方法可以根据应用程序的需求和情况来选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值