本文摘自PHP中文网,作者(*-*)浩,侵删。
正常来说,一般是不会出现这种情况的,但也不能保证,偶尔有这种情况发生,解决方案如下:

使用分页查询语句。 (推荐学习:mysql学习)
因为分页查询每次只会查询少量数据,所以不会占用太多内存,而且数据量很大的时候,分页查询会节约一些时间的。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | 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参数配置
阅读剩余部分
相关阅读 >>
sql中的名称由什么组成?
一条 sql 查询语句怎么样执行的?
sql优化老出错,那是你没弄明白mysql解释计划用法
sql中datediff函数怎么用?(代码详解)
详解mysql数据库千万级数据查询和存储
sql注入之必备的基础知识
很全的sql中文解释代码
mssql 大量数据时,建立索引或添加字段后保存更改提示超时的解决方法
sql语句中含有乘号报错的处理办法
mysql的select 学习笔记
更多相关阅读请进入《sql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » sql查询数据过多内存溢出怎么办