行业资讯 2025年08月6日
0 收藏 0 点赞 327 浏览 1275 个字
摘要 :

文章目录 一、思路 二、实现 三、进阶操作 本文主要讲解关于Java如何查询导出百万数量级excel数据相关内容,让我们来一起学习下吧! 一、思路 拆分(肯定不能一次io返……




  • 一、思路
  • 二、实现
  • 三、进阶操作

本文主要讲解关于Java如何查询导出百万数量级excel数据相关内容,让我们来一起学习下吧!

一、思路

  1. 拆分(肯定不能一次io返回百万数据,服务可能直接就崩,数据库性能也会受到影响,进而影响其他业务)
  2. 异步查询(如果是同步等待,时间过长,会造成前端接口直接504,网关超时)
  3. 多线程

二、实现


@Slf4j
@Service
public class UsersService {
    /**
     * 一个线程查1w条
     */
    private final Integer threadUserCount = 10000;
    @Autowired
    private UserMapper userMapper;

    public List<User> batchFind(Integer count) {
        // 返回的数据集
        CopyOnWriteArrayList<User> userList = new CopyOnWriteArrayList<>();
        // 数据总量
        Integer countUser = userMapper.countUser();
        // 需要创建的线程数量
        int threadCount = countUser / threadUserCount + 1;
        // 线程计数器
        final CountDownLatch threadFlag = new CountDownLatch(threadCount);
        // 创建线程池
        ExecutorService executorService = Executors.newFixedThreadPool(threadCount);

        for (int i = 0; i < threadCount; i++) {
            // 该线程起始数据
            int start = i * threadUserCount;
            int threadIndex = i + 1;
            executorService.execute(() -> {
                List<User> users = userMapper.pageFind(start, threadCount);
                userList.addAll(users);
                log.info(String.format(\"execute [%s]  thread ,thread data count %s\", threadIndex, users.size()));
                //计数器-1
                threadFlag.countDown();
            });
        }
        
        try {
            // 同步等待 所有的线程执行完
            threadFlag.await();
        } catch (InterruptedException e) {
            log.warn(e.getMessage());
        }
        return userList;
    }
}


三、进阶操作

问题:如果百万的数据,都查出来放在内存,然后需要往外写(导出excel),会使得服务内存飙高,甚至OOM 挂掉。

思路:

  1. 将读取出来的数据存到队列(第三方的rabbitMQ等)
  2. 读写分离(一个线程读,多线程去做导出)
  3. 使用EasyExcel

以上就是Java如何查询导出百万数量级excel数据相关的全部内容,希望对你有帮助。欢迎持续关注潘子夜个人博客(www.panziye.com),学习愉快哦!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/9863.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

986
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

463
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

347
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

455
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

516
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

831
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号