news 2026/4/23 10:29:16

MyBatis隐形炸弹:selectByExampleWithBLOBs使用不当性能下降80%

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MyBatis隐形炸弹:selectByExampleWithBLOBs使用不当性能下降80%

01 引言

在MyBatis项目开发中,你是否遇到过查询突然变慢、内存占用飙升的困扰?这很可能是selectByExampleWithBLOBs使用不当导致的性能陷阱。

本文将为你揭秘这个看似简单却暗藏玄机的方法,从使用场景到性能优化,助你掌握BLOB字段查询的精髓,避免常见坑点。

02 缘起

这两天遇到一个线上BUG,就是因为selectByExampleWithBLOBs问题导致的。如图所示:

从报错的日志信息来看,是因为selectByExampleWithBLOBs没有绑定Mapper.xml文件。

问题很快就排查了,因为新加了字段需要使用逆向工程(MBG)重新生成实体。而生成的实体的时候,开发者对Text类型的字段直接指定了类型,导致BLOB字段丢失,Mapper.xml也不会有xxxxWithBLOBs的方法,导致问题产生。

默认的映射是将Text字段单独拿出来,使用xxxWithBLOBs单独接收,对应的xml也会生成类似selectByExampleWithBLOBs的方法,如图:

接下我们将一起探索xxxWithBlobs的用法。

03 概述

selectByExampleWithBLOBs是MyBatis Generator(MBG)自动生成代码时针对包含BLOB(Binary Large Object)字段的表的查询方法。它允许通过Example条件对象进行查询,同时包含对BLOB字段的检索。

当数据库表中包含BLOB、CLOB、TEXT等大字段类型时,MBG会生成两个查询方法:

  • selectByExample:查询时不包含BLOB字段
  • selectByExampleWithBLOBs:查询时包含BLOB字段

04 代码示例

4.1 数据库表结构

sql CREATE TABLE `article` ( `id` int(11) NOT NULL AUTO_INCREMENT, `title` varchar(200) NOT NULL, `author` varchar(100) DEFAULT NULL, `content` longtext, -- BLOB类型字段 `summary` text, -- BLOB类型字段 `create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

4.2 自动生成实体以及配置

MyBatis Generator自动生成代码工具这里就详细说明了,直接使用工具生成。

我们可以看到ArticleWithBLOBs继承BaseArticle数据库实体类,content和summary已经单独处理了。

xml配置文件也有类似的方法:

4.3 使用

xxxWithBLOBs的使用很简单,就和selectByExample几乎一样。

java // 创建Example对象 ArticleExample example = new ArticleExample(); ArticleExample.Criteria criteria = example.createCriteria(); // 设置查询条件 criteria.andAuthorEqualTo("张三") .andCreateTimeGreaterThan(DateUtils.addDays(new Date(), -7)); // 排序 example.setOrderByClause("create_time DESC"); // 1. 普通查询(不获取content字段) List<Article> articles1 = articleMapper.selectByExample(example); // 2. 包含BLOB字段的查询 List<ArticleWithBLOBs> articles2 = articleMapper.selectByExampleWithBLOBs(example); // 此时articles2中的每个Article对象都包含content字段的数据

selectByExample和selectByExampleWithBLOBs的返回值不一样哦。

05 注意事项

5.1 性能问题

MBG为什么要把Text类型的字段单独处理呢?会有什么性能问题么?

Text字段通常存储大量数据,如文章内容、协议内容等,大数据量传递会消耗带宽以及IO等,从而影响性能。

所以,查询时不需要Text类型的字段时,尽量不要查询。遵循需要什么查什么的最少资源的模式,可以提高接口性能。

java // 不推荐:不必要的BLOB查询 ArticleExample example = new ArticleExample(); example.createCriteria().andStatusEqualTo(1); // 如果只需要统计数量或非BLOB字段,应使用普通查询 List<Article> articles = articleMapper.selectByExample(example); // 更好 // 需要BLOB数据时才使用WithBLOBs List<ArticleWithBLOBs> articlesWithBlobs = articleMapper.selectByExampleWithBLOBs(example);

5.2 字段排除与包含

MBG配置中可以控制BLOB字段的生成策略:

xml <table tableName="article" domainObjectName="Article"> <property name="useActualColumnNames" value="false" /> <property name="domainPackage" value="base" /> <columnRenamingRule searchString="is_" replaceString="" /> <!-- 默认映射 --> <columnOverride column="content" javaType="String" jdbcType="LONGVARCHAR"/> </table>

columnOverride用来指定生成的字段类型,上述代码为默认映射,可以通过指定jdbcType或者javaType来干涉生成的字段。

5.3 ResultMap差异

MBG会生成两个ResultMap:

  • BaseResultMap:不包含BLOB字段
  • ResultMapWithBLOBs:包含BLOB字段

5.4 Mapper兼容

selectByExampleWithBLOBs为MGB默认方法,生成的xxxMapper可能会不包此方法,这个和MGB这个工具有关系。我的工具里面就没有。

需要手动处理。

06 小结

小编觉得selectByExampleWithBLOBs应该做到非必要不使用,减少资源的消耗。如果存储的数据没有非常大的时候,应该避免使用text等大数据类型的。合理使用才是性能优化的关键,让大数据字段不再成为系统负担。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 13:13:17

【更新至2024年】2007-2024年上市公司cnrds ESG评分数据

【更新至2024年】2007-2024年上市公司cnrds ESG评分数据 1、时间&#xff1a;2007-2024年 2、来源&#xff1a;cnrds 3、指标&#xff1a;股票代码、公司简称、会计年度、ESG得分、ESG排名、E得分、E排名、S得分、S排名、G得分、G排名 4、范围&#xff1a;A股上司公司 5、…

作者头像 李华
网站建设 2026/4/23 12:16:10

选择画面中加一个自定义按钮

效果代码实现REPORT ztest_button." 引入这个表是为了能够使用 sscrfields 结构 TABLES: sscrfields. " 定义一个功能文本结构 DATA: functxt TYPE smp_dyntxt." --- 【关键步骤】声明按钮 --- " 这行代码告诉系统&#xff1a;我要在工具栏上启用第 1 个功…

作者头像 李华
网站建设 2026/4/23 12:15:55

【课程设计/毕业设计】基于SpringBoot + Vue的医院预约挂号系统的设计与实现基于SpringBoot社区医疗预约挂号平台的设计与实现【附源码、数据库、万字文档】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/21 17:39:50

ArcGIS数据库文件和普通文件添加字段的区别

普通的shp文件添加字段时&#xff0c;如果字段类型是数字类型的&#xff0c;例如短整型&#xff0c;则在添加字段时&#xff0c;就会自动赋予其属性值为0。则在进行属性界定时&#xff0c;若要赋予0值为特殊含义&#xff0c;就很不方便。而数据库中的矢量数据&#xff0c;添加字…

作者头像 李华
网站建设 2026/4/23 10:12:35

[STM32C0] 【STM32C092RC 测评】+08 定时器1输出可变脉宽

今天对脉冲宽度进行测试&#xff1a;一&#xff1a;PWM脉宽知识分享&#xff1a; PWM&#xff08;脉冲宽度调制&#xff09;的脉冲宽度是指在一个周期内信号处于高电平&#xff08;或有效状态&#xff09;的时间长度&#xff0c;通常用时间单位&#xff08;如微秒μs、毫秒ms&a…

作者头像 李华
网站建设 2026/4/23 10:11:31

[STM32C0] 【STM32C092RC 测评】+ 03 板载串口2输出测试

一&#xff1a;通用同步/异步收发器(USART) 这些设备嵌入四个通用同步/异步接收器/发送器&#xff0c;其通信速度高达6 Mbit/s。 它们提供CTS、RTS和RS485 DE信号的硬件管理、多处理器通信模式、同步SPI通信和单线半双工通信。 双工通信模式。有些还支持智能卡通信(ISO7816)、I…

作者头像 李华