《mybatis》--大数据量查询解决方案

阿丹-需求/场景:

之前写百万以及千万的导出数据的时候,对于将数据写道csv文件并压缩这里没有什么大问题了,但是出现了其他问题为:

1、我们需要将数据从数据库中拿出来,并且在进行装配的时候出现了一些问题。

2、对于整体内存安全来说,如果直接将数据从数据库中拿出来百万级别以上的数据对于内存是非常不友好的。当问题出现比较大的时候会直接触发GC,造成瘫痪。

目前开发以及项目测试的是更多的使用mybatis来进行开发的,所以本文章讨论以及解决的的就是如何使用mybaits来解决流式查询并单条处理的问题。

解决方案:

使用MyBatis查询超大数据时,为了避免内存溢出(OOM, OutOfMemoryError)问题,可以采用以下几种解决方案:

  1. 流式查询 (Stream Result)

    • MyBatis 提供了<select>标签的resultType="void"配合<resultMap>useResultHandler="true"属性来实现流式查询。通过定义一个ResultHandler接口的实现类,MyBatis会在遍历结果集的过程中逐行调用处理方法,这样每处理一行就释放一行的数据,从而避免一次性加载所有数据到内存中。

      <select id="streamingQuery" statementType="CALLABLE" resultType="void"> {your_query_here} </select>

    在Java代码中:

    复制代码
    sqlSession.select("streamingQuery", parameter, new ResultHandler() {
        @Override
        public void handleResult(ResultContext context) {
            Object object = context.getResultObject();
            // 处理单行数据并确保及时释放资源
        }
    });
  2. 分页查询 (Pagination)

    • 如果业务允许,对数据进行分页查询是最常见的做法,每次仅从数据库获取一部分数据。
    • 在MyBatis中可以通过动态SQL或者参数绑定实现分页,例如使用PageHelper等第三方分页插件。
  3. 游标查询 (Cursor)

    • 对于支持游标的数据库(如Oracle、PostgreSQL等),可以利用数据库层面的游标特性,在不关闭连接的情况下逐步读取结果集。
    • MyBatis 3.4.6版本及更高版本直接支持JDBC ResultSet类型的返回值,结合Statement#setFetchSize()方法可以实现类似游标的效果,有效地控制内存占用。
  4. 优化SQL查询

    • 减少不必要的字段查询,只取出需要的列。
    • 使用JOIN或子查询时,注意是否能进一步优化SQL语句以减少结果集大小。
    • 避免在应用层做大量计算和数据转换,尽量让数据库完成复杂过滤和聚合操作。
  5. 分布式处理或批处理

    • 如果数据量实在太大,可以考虑将任务分解为多个小任务,每个任务处理部分数据,然后汇总结果。
  6. 数据库端缓存与分片策略

    • 在数据库层面对大表进行分区或索引优化,减少单次查询的数据量。

选择哪种方案取决于具体的应用场景、数据库类型以及系统架构设计。流式查询通常是在内存限制严格且必须一次性处理大量数据时的最佳实践。

相关推荐
fengxin_rou6 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
老毛肚16 小时前
MyBatis插件原理及Spring集成
java·spring·mybatis
马尔代夫哈哈哈21 小时前
MyBatis 入门与实战:从配置到CRUD一站式指南
mybatis
Jul1en_1 天前
【MyBatis/plus】核心配置、插件与 MyBatis-Plus 构造器 Wrapper
mybatis
LiZhen7981 天前
SpringBoot 实现动态切换数据源
java·spring boot·mybatis
我是Superman丶1 天前
在 PostgreSQL 中使用 JSONB 类型并结合 MyBatis-Plus 实现自动注入,主要有以下几种方案
数据库·postgresql·mybatis
Pluto_CSND1 天前
基于mybatis-generator插件生成指定数据表的实体类、xml文件和dao层接口
mybatis
indexsunny1 天前
互联网大厂Java面试实战:微服务与Spring生态技术解析
java·spring boot·redis·kafka·mybatis·hibernate·microservices
手握风云-1 天前
JavaEE 进阶第十六期:MyBatis,查询请求的生命周期全景图(一)
java·java-ee·mybatis
独断万古他化1 天前
【SSM开发实战:博客系统】(二)JWT 登录流程、拦截器实现和用户信息接口落地
spring boot·spring·mybatis·博客系统·项目