MySQL的JDBC OutOfMemoryError: Ja…
来源:互联网 发布:美国电话号码格式 知乎 编辑:程序博客网 时间:2024/06/17 17:37
转自:http://blog.csdn.net/miraclestar/article/details/6623138
MySql数据库通过JDBC对大表进行查询时抛出java.lang.OutOfMemoryError: Java heapspace异常。这是因为默认情况下,MySQL的JDBC驱动会一下子把所有row都读取下来,这在一般情况下是最优的,因为可以减少Client-Server的通信开销。但是这样也有一个问题,当数据库查询结果很大时,特别当不能全部放进内存时,就会产生性能问题。
本 来,JDBCapi里在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的,从这里也可以看出两者的考量不同。
MySql数据库通过JDBC对大表进行查询时抛出java.lang.OutOfMemoryError: Java heapspace异常。这是因为默认情况下,MySQL的JDBC驱动会一下子把所有row都读取下来,这在一般情况下是最优的,因为可以减少Client-Server的通信开销。但是这样也有一个问题,当数据库查询结果很大时,特别当不能全部放进内存时,就会产生性能问题。
本 来,JDBCapi里在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.以下两句语句选一即可:
这样会一行一行地从Server读取数据,因此通信开销很大,但内存问题可以解决。官方的说法是不支持fetchSize不是MySQL的JDBC驱动的问题,而是MySQL本身就不支持。而商用数据库Oracle或DB2都是支持fetchSize的,从这里也可以看出两者的考量不同。
考虑到应用程序利用JDBC跨数据库的特性可以,通过判断mySql连接特殊处理:
0 0
- MySQL的JDBC OutOfMemoryError: Ja…
- JSP 通过 jdbc-odbc 连接 mysql 出…
- buildbot + bazaar + mysql的测试…
- java.lang.Thread 和 ja…
- MySQL Online DDL …
- MySQL server has …
- 快速入门:使用承诺(使用 Ja…
- 在Sublime Text2中编译执行Ja…
- Android 4.1以上实现归属地JA…
- Java语言编程入门零基础学 ja…
- Mysql ERROR 1045 (28000): Access…
- jdbc 调用 sql ser…
- Java JDBC Thin Dr…
- MySQL的ODBC JDBC官方驱动包
- java.lang.OutOfMemoryError: Java…
- java.lang.OutOfMemoryError:&nbsp…
- java.lang.OutOfMemoryError:&nbsp…
- java.lang.OutOfMemoryError: Perm…
- java向MySQL插入当前时间的四种方式和java时间日期格式化的几种方法(案例说明)
- mysql存储引擎选择
- 设计数据库时考虑的因素
- Query语句的优化
- java.util.ConcurrentModification…
- MySQL的JDBC OutOfMemoryError: Ja…
- MySQL的嵌套查询
- 修改mysql提示符显示内容方法
- mysql warnings 和整数越界
- 面试失败后各国青年的不同反…
- java初学者应该注意的问题
- python 面向对象详解
- java基础程序题 判断一个字符串是否为回文 运用正则表达式处理字符串
- java finalize的一些问题