Cursor搜索大量数据使用

该代码示例展示了如何在Java中利用Cursor处理大量数据库查询结果,避免一次性加载到内存。在@Transactional注解的事务管理下,通过ExcelUtil生成大文件,遍历Cursor将数据写入Excel行,确保了内存效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 这是一个游标的概念,当获取大量数据的时候则使用Cursor存储,不用List存储
  • 需要配合@Transactional使用才生效
  • 业务场景:搜索数据库大量数据出来,然后遍历Cursor将数据写入并生成指定文件
 @Transactional
    public String export(InteractiveReplyStatistics interactiveReplyStatistics, User user, List<Integer> userIdsByRole) {
        ExcelWriter writer = null;
        String filename = IdUtil.fastSimpleUUID() + ".xlsx";
        String filepath = localStoreDirConfig.getLocalExportFileStoreDirPath() + "/" + filename;
        try {
            int count = interactiveReplyStatisticsMapper.countByAllGroupByBatchNo(interactiveReplyStatistics, userIdsByRole);
            if (count > Symbols.API_MAX_EXPORT) {
                return null;
            }

            Cursor<InteractiveReplyStatistics> cursor = interactiveReplyStatisticsMapper.steamByAllGroupByBatchNo(interactiveReplyStatistics, userIdsByRole);
            writer = ExcelUtil.getBigWriter(filepath);
            ArrayList<String> temp = new ArrayList(){{
                add("日期");
                add("批次号");
                add("提交人");
                add("短信标题");
                add("回复应答码");
                add("回复条数");
            }};
            writer.writeHeadRow(temp);

            Iterator<InteractiveReplyStatistics> iterator = cursor.iterator();
            while (iterator.hasNext()) {
                InteractiveReplyStatistics o = iterator.next();
                if (o == null) {
                    break;
                }
            
                // 写入文件
                temp.clear();
                temp.add(DateUtil.formatDate(o.getStatTime()));
                temp.add(o.getAncestorBatchNo());
                temp.add(o.getUserName());
                temp.add(o.getTaskName());
                temp.add(o.getAnswerCode());
                temp.add(o.getAnswerCount()+"");
                writer.writeRow(temp);
            }

            writer.flush();
        } catch (Exception e) {
            logger.error(e);
        } finally {
            if (writer != null) {
                writer.close();
            }
        }

     

        return filename;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值