直接使用数据库教程的分页sql获得子集.而不在内存中操作. 这样的好处是将子集放到一个中间结果里,每次再将中间结果合并到目标结果集.避免内存中同时出现二个大的结果集
1. 一种全部查询到内存,然后使用subList, subList的场景比如in参数的限制.
private List
List
if (cpcList == null || cpcList.size() <= 0)
return null;
List
int group = cpcList.size() % IDS_PER_BATCH == 0 ? cpcList.size()
/ IDS_PER_BATCH : (cpcList.size() / IDS_PER_BATCH + 1);
for (int i = 0; i < group; i++) {
String sql = "SELECT * FROM QUALITYHISTORY A WHERE A.GROUPID="
+ groupid
+ " AND A.ACCOUNTID="
+ accountid
+ " AND A.KEY IN ("
+ DtoBaseUtility
.getOtherStringFromEntitySet(
cpcList
.subList(
i * IDS_PER_BATCH,
((i + 1) * IDS_PER_BATCH) > cpcList
.size() ? cpcList
.size()
: ((i + 1) * IDS_PER_BATCH)),
CpcKeyDTO.class, "getKey") + ")";
;
List
.queryWithSpecifiedClassType(sql, QualityHistory.class,
jdbcTemplateCpc);
if (ls != null) {
res.addAll(ls);
}
}
return res;
}
.
......
for (int pageNo = 1; pageNo <= totalPageCount; pageNo++) {
doPage(sql, pageNo, set);
}......
private void doPage(String sql, int pageNo, Setset) {
long t1 = System.currentTimeMillis();
final int startIndex = PageUtil.getStartOfPage(pageNo, pageSize);
String sqlLimit = PageUtil.getLimitString(sql, true);
Object[] obj = new Object[] { startIndex, startIndex + pageSize };
Listlist = jdbcTemplateCpc.query(sqlLimit, obj,
new RowMapper() {@Override
public Object mapRow(ResultSet rs, int arg1)
throws SQLException {
return "" + rs.getString(2) + rs.getString(1);
}});
set.addAll(list);
long t2 = System.currentTimeMillis();
logger.info("第" + pageNo + "次查询数据量" + list.size() + ",set中现有"
+ set.size() + "条记录,耗时" + ((t2 - t1) / 1000) + "秒");
}
敢达决战官方正版 安卓版v6.7.9
下载敢达决战 安卓版v6.7.9
下载像素火影骨架佐助 (Perseverance Fire Shadow)手机版v1.16
下载要塞英雄 安卓版v33.20.0-39082670-Android
下载梦想城镇vivo最新版本 安卓版v12.0.1
梦想城镇vivo版是这款卡通风模拟经营类手游的渠道服版本,玩
怦然心动的瞬间 安卓版v1.0
怦然心动的瞬间是一款真人向的恋爱互动游戏,在游戏中玩家将扮演
曼尼汉堡店游戏 安卓版v1.0.3
曼尼汉堡店是一款非常好玩的精品恐怖类型冒险游戏,在这款游戏中
现代总统模拟器去广告版 安卓版v1.0.46
现代总统模拟器是一款休闲养成类游戏,可能对于不少的玩家来说都
现代总统模拟器付费完整版 安卓版v1.0.46
现代总统模拟器高级版在商店是需要付费的,相对于普通版本,高级