数据库流式查询

数据库流式查询

数据库流式查询是一种边读取边处理数据的查询方式,不会一次性将全量结果加载到内存,能大幅降低内存占用,避免大数据量场景下的OOM问题,同时省去手动分页的复杂逻辑。

一、核心特点

  • 内存友好:数据逐行/小批次读取处理,处理完即释放,百万级数据场景下内存峰值可低至几十MB。
  • 性能稳定:无需深度分页,仅执行一次查询,避免分页查询的多次IO开销。
  • 实时处理:读取数据的同时可同步执行业务逻辑,适配低延迟处理需求。

二、主流实现方式

  1. MyBatis/MyBatis-Plus 游标实现
    通过Cursor迭代器逐条获取数据,需保持数据库连接开启,搭配@Transactional和try-with-resources使用,是Java生态最常用的方案。
  2. ResultHandler 回调方式
    通过@Options注解配置流式参数,查询结果直接回调处理,无需手动管理迭代器,适配简单数据处理场景。
  3. 云原生流数据库方案
    如Azure Databricks结构化流、RisingWave等,支持直接从Kafka、云存储等数据源实时流式读取,适配实时分析、事件驱动场景。

三、典型应用场景

  • 百万/千万级大数据量导出、数据迁移
  • 实时数据流处理(如金融交易、物联网数据采集)
  • 低内存资源环境下的海量数据遍历处理

四、代码示例

java 复制代码
package com.example.mapper;

import com.example.entity.User;
import org.apache.ibatis.annotations.*;
import org.apache.ibatis.cursor.Cursor;
import org.apache.ibatis.session.ResultHandler;

import java.util.List;

@Mapper
public interface UserMapper {

    /**
     * 方式一:使用 Cursor 进行流式查询
     * 注意:
     * 1. 返回类型必须是 Cursor<T>
     * 2. 需要配合 @Options 设置 fetchSize 和 resultSetType
     * 3. 调用方必须保持事务开启,并在 try-with-resources 中关闭 Cursor
     */
    @Select("SELECT id, username, email, age FROM users")
    @Options(resultSetType = ResultSetType.FORWARD_ONLY, fetchSize = 1000)
    Cursor<User> selectAllUsersWithCursor();

    /**
     * 方式二:使用 ResultHandler 进行流式回调处理
     * 注意:
     * 1. 返回类型必须是 void
     * 2. 最后一个参数必须是 ResultHandler<T>
     * 3. MyBatis 每读取一行数据就会调用 handler.handleResult
     */
    @Select("SELECT id, username, email, age FROM users")
    @Options(resultSetType = ResultSetType.FORWARD_ONLY, fetchSize = 1000)
    void selectAllUsersWithHandler(ResultHandler<User> handler);
 }
相关推荐
彦为君1 小时前
算法思维与经典智力题
java·前端·redis·算法
翔云 OCR API1 小时前
慧视扫描王-财务少加班
java·自动化
雨辰AI1 小时前
生产级实战:人大金仓 V9 标准化运维手册(日常巡检 + 监控告警 + 应急处置)
java·运维·数据库·后端
我是一颗柠檬1 小时前
【Java项目技术亮点】覆盖索引与索引下推优化
android·java·开发语言
云道轩1 小时前
比较IBM Transformation Advisor 和WebSphere Application Server Migration Toolkit
java·jakarta ee·open liberty·应用迁移
2601_962440842 小时前
计算机毕业设计之健身房管理系统的设计与实现
java·开发语言·课程设计·旅游·宠物
TeamDev2 小时前
JxBrowser 9.3.0 版本发布啦!
java·后端·c#·混合应用·jxbrowser·浏览器控件·异步媒体设备
深盾科技_Virbox2 小时前
深盾科技·Virbox产品体系全景解读:软件安全如何从加密锁走向全生命周期
java·大数据·算法·安全·软件需求
豆瓣鸡2 小时前
Knife4j 接口文档
java