几十万的数据量,无法一个查询搞定怎么办,可以尝试分段查询.

之前在项目中处理过数据量比较大的场景.如果数据库中有几十万条数据,一条sql查询时间太久,可能还会导致整个程序down掉.后来的优化方案就是分段读取,一次读取个几千条,然后把查询结果都放在一起. 主要的思想就是类似分页查询的逻辑.

int size = 10000;
//curDayOrdCount 是通过查询出来的一个数据量总数,来计算总共要分多少页
int totalPage = curDayOrdCount % size == 0 ? curDayOrdCount / size : (curDayOrdCount / size) + 1;
List<OrdLogSyn> ordLogSyns = null;
long readStart = System.currentTimeMillis();
log.info(LogHelper.info(baseProcess,"支付交易成功的笔数为【"+curDayOrdCount+"】笔,开始读取数据库.............."));
for (int i = 0; i < totalPage; i++) {
    int start2 = i * size + 1;
    int preEnd2 = size * (i + 1);
    int end2 = preEnd2 > curDayOrdCount ? curDayOrdCount : preEnd2;
    List<OrdLogSyn> ordLogSynList = ordLogSynMapper.batchQuery("AP", yesterday, start2, end2);
    log.info(LogHelper.info(baseProcess,"第【" + start2 + "】条 ======= 第【" + end2 + "】条数据读取完毕........."));
    if (ordLogSyns == null && ordLogSynList != null){
        ordLogSyns = ordLogSynList;
    }else if (ordLogSynList != null){
        ordLogSyns.addAll(ordLogSynList);
    }
}
long readEnd = System.currentTimeMillis();
log.info(LogHelper.info(baseProcess,"读取"+curDayOrdCount+"条数据耗时"+(readEnd-readStart)/1000+"秒"));

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值