百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

大数据量查询容易OOM?试试MySQL流式查询

csdh11 2025-01-02 15:31 4 浏览

一、前言

程序访问 MySQL 数据库时,当查询出来的数据量特别大时,数据库驱动把加载到的数据全部加载到内存里,就有可能会导致内存溢出(OOM)。

其实在 MySQL 数据库中提供了流式查询,允许把符合条件的数据分批一部分一部分地加载到内存中,可以有效避免OOM;本文主要介绍如何使用流式查询并对比普通查询进行性能测试。

二、JDBC实现流式查询

使用JDBC的 PreparedStatement/StatementsetFetchSize 方法设置为 Integer.MIN_VALUE 或者使用方法 Statement.enableStreamingResults() 可以实现流式查询,在执行 ResultSet.next() 方法时,会通过数据库连接一条一条的返回,这样也不会大量占用客户端的内存。

public int execute(String sql, boolean isStreamQuery) throws SQLException {
    Connection conn = null;
    PreparedStatement stmt = null;
    ResultSet rs = null;
    int count = 0;
    try {
        //获取数据库连接
        conn = getConnection();
        if (isStreamQuery) {
            //设置流式查询参数
            stmt = conn.prepareStatement(sql, ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_READ_ONLY);
            stmt.setFetchSize(Integer.MIN_VALUE);
        } else {
            //普通查询
            stmt = conn.prepareStatement(sql);
        }

        //执行查询获取结果
        rs = stmt.executeQuery();
        //遍历结果
        while(rs.next()){
            System.out.println(rs.getString(1));
            count++;
        }
    } catch (SQLException e) {
        e.printStackTrace();
    } finally {
        close(stmt, rs, conn);
    }
    return count;
}

PS:上面的例子中通过参数 isStreamQuery 来切换流式查询普通查询,用于下面做测试对比。

三、性能测试

创建了一张测试表 my_test 进行测试,总数据量为 27w 条,分别使用以下4个测试用例进行测试:

  1. 大数据量普通查询(27w条)
  2. 大数据量流式查询(27w条)
  3. 小数据量普通查询(10条)
  4. 小数据量流式查询(10条)

3.1. 测试大数据量普通查询

@Test
public void testCommonBigData() throws SQLException {
    String sql = "select * from my_test";
    testExecute(sql, false);
}

3.1.1. 查询耗时

27w 数据量用时 38 秒

3.1.2. 内存占用情况

使用将近 1G 内存

3.2. 测试大数据量流式查询

@Test
public void testStreamBigData() throws SQLException {
    String sql = "select * from my_test";
    testExecute(sql, true);
}

3.2.1. 查询耗时

27w 数据量用时 37 秒

3.2.2. 内存占用情况

由于是分批获取,所以内存在30-270m波动

3.3. 测试小数据量普通查询

@Test
public void testCommonSmallData() throws SQLException {
    String sql = "select * from my_test limit 100000, 10";
    testExecute(sql, false);
}

3.3.1. 查询耗时

10 条数据量用时 1 秒

3.4. 测试小数据量流式查询

@Test
public void testStreamSmallData() throws SQLException {
    String sql = "select * from my_test limit 100000, 10";
    testExecute(sql, true);
}

3.4.1. 查询耗时

10 条数据量用时 1 秒

四、总结

MySQL 流式查询对于内存占用方面的优化还是比较明显的,但是对于查询速度的影响较小,主要用于解决大数据量查询时的内存占用多的场景。

DEMO地址https://github.com/zlt2000/mysql-stream-query

相关推荐

usb2.0和3.0的区别

提到USB,就不得不提到他——AjayBhatt。那时计算机完全依赖串口和并口连接外设,像鼠标、打印机、手柄之类,速度很慢、驱动复杂,更不用说同时工作。为了解决这些问题,Bhatt提出了“通用串行总...

超级全的宝马模块缩写、常用缩写、中英对照,值得收藏

AAustauschbar可替换通过零件号码下一行ABAirbag安全气囊ABEAllgemeineBetriebserlaubnis普通操作许可证ABSAnti-Blockie...

Ubuntu下显卡驱动安装

导读本文将介绍如何在...

智嵌物联USB-CAN调试器使用方法介绍

技术人员在开发调试CAN总线时,往往需要分析CAN报文数据,这时就需要一个PC机上的CAN调试器了。智嵌物联ZQWL研发的CAN调试器使用方便,稳定可靠,性价比高。单路CAN调试器有ZQWL-UCAN...

三菱编程软件GX WORKS2的安装和调试

从三菱官网下载的GXWORKS2经解压后有4个文件夹(Disk1-4),如果只需要编程的话我们只安装Disk1。打开文件夹,双击setup.exe文件,按提示逐步完成安装,过程中会提示输入用户名、公...

揭秘|U盘用完之后到底能不能直接拔掉?看完这篇文章你就明白啦

现在U盘已经成为我们生活学习中必不可少的一部分了,不管你是什么职业,可能是学生、老师、医生、记者等等。只要你的工作和电脑打交道,你肯定就要有一个U盘,U盘以他的便携性和方便在可移动磁盘中脱颖而出。但是...

MAIWO存储学堂:USB接口全家族详解!

USB接口,可以说是人们最熟悉的接口,几乎无处不在。USB接口自从1996年推出后,已成功替代串口和并口,成为二十一世纪个人电脑和大量智能设备的必配接口之一。那么,USB接口究竟是何来头?USB(Un...

(干货)两款USB芯片CH340与CH341常见问题解答

芯片供电注意事项CH340/CH341等USB芯片都支持5V和3.3V电源电压,5V供电时芯片V3引脚需要接一个104电容到地,3.3V供电时需要注意以下几点:★与US...

SSD并不可怕 设置不当掉速毁盘才可怕

SSD固态硬盘如今成为装机配置中的必选产品,动辄500-600MB/秒的读写速度,可能因为主板、SSD设置不对,SSD的性能没有真正发挥出来。硬盘掉速问题最早来源于机械硬盘,性能多达5倍于机械硬盘的S...

GEEK范:30块钱给机箱加个小屏幕

作者:casatift这篇文章主要是受到Mr_Smiles的《大龄男青年的小玩具,篇一:VFD屏》的启发,在加了2个星期班以后实在没有心情再干活,就用桌上的小玩意拼了个类似的小屏幕。当然,原件受限,...

优盘有时提示无法识别,是什么原因造成的?了解优盘原理轻松搞定

前言无法识别的USB设备?这个故障通常会是USB接口供电不足的原因,或者接触不良引起;也有的是系统或者优盘本身的原因;老修的解决经验,通常换一个USB接口就能解决了,大多是主机的前置供电不足或USB不...

NUC980 移植移远EC20驱动(GobiUSBNet)

移植过程中,参考的是移远官方的参考手册《Quectel_WCDMA<E_Linux_USB_Driver_User_Guide_V1.8》等。1、添加USB设备信息先在Linux内核中添加EC...

科普:USB有A口和C口,那有没有B口?

前言在多媒体电脑问世时,外接式设备(例如键盘鼠标等)的传输规范各不相同;如打印机只能接LPT、调制解调器只能接RS232、鼠标键盘只能接PS/2等;并且繁杂的系统、必须安装的驱动程序以及重新开机才允许...

帝特usb转串口驱动——电脑驱动程序锐减

帝特usb转串口驱动是帝特为旗下US串口线产品打造的驱动程序,通过安装驱动便能够使用其USB转串口的产品。在此驱动程序中包含了旗下所有系列产品的驱动,并且包含了Windows、MAC、Linux等平台...

【驱动】串口驱动分析(三)-serial driver

简介前两节我们介绍串口驱动的框架和ttycore部分。这节我们介绍和硬件紧密相关的串口驱动部分。...