sql查询数据过多内存溢出怎么办

互联网 19-10-28
正常来说,一般是不会出现这种情况的,但也不能保证,偶尔有这种情况发生,解决方案如下:

使用分页查询语句。 (推荐学习:mysql学习)

因为分页查询每次只会查询少量数据,所以不会占用太多内存,而且数据量很大的时候,分页查询会节约一些时间的。

String sql = " SELECT uid,uname  FROM t_user LIMIT ?,? " ;         PreparedStatement  ps = con.prepareStatement(sql) ;         int pageSize = 10000;          int pageId = 0;          do {              pst.setInt(1, pageId * pageSize);              pst.setInt(2, pageSize);              ResultSet rs = pst.executeQuery();              boolean isEmpty = true;              while (rs.next()) {                   isEmpty = false;                   id = rs.getInt(1);                   name = rs.getString(2);              }              if (isEmpty) {                  break;              }              pageId++;          } while (true);          con.close();      } catch (SQLException e) {          e.printStackTrace();      }

添加url参数配置

"jdbc:mysql://localhost:3306/db3?useCursorFetch=true&defaultFetchSize=100";

( 解释一下Fetch,当我们执行一个SQL查询语句的时候,需要在客户端和服务器端都打开一个游标,并且分别申请一块内存空间,作为存放查询的数据的一个缓冲区。这块内存区,存放多少条数据就由fetchsize来决定,同时每次网络包会传送fetchsize条记录到客户端 )

以上就是sql查询数据过多内存溢出怎么办的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: 基础知识
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:db2修改字段长度

相关资讯