news 2026/4/18 11:32:04

MyBatis条件拼接失效?一招解决!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MyBatis条件拼接失效?一招解决!

问题背景

在前后端联调过程中,前端传递的参数在后端断点调试时能够正确接收,但在 MyBatis 的mapper.xml文件中,条件拼接却失效。原本使用常见的<if>标签检查参数是否为空,但始终无法生效。

原因分析

常见的<if test="dto.acb21a!=null and dto.acb21a!=''">写法在某些情况下可能无法正确判断字符串是否为空或空白。尤其是在参数为字符串类型时,空字符串或空白字符的判断可能不够严谨,导致条件逻辑未按预期执行。

解决方案

改用org.apache.commons.lang3.StringUtils工具类的isNotBlank方法,可以更严格地判断字符串是否非空且非空白。以下是优化后的代码示例:

<if test="@org.apache.commons.lang3.StringUtils@isNotBlank(dto.acb21a)"> <choose> <when test='dto.acb21a == "2"'> AND (BCC21B BETWEEN 1700 AND 1999 OR BCC21A BETWEEN 1700 AND 1999) </when> <when test='dto.acb21a == "3"'> AND (BCC21B BETWEEN 2000 AND 2999 OR BCC21A BETWEEN 2000 AND 2999) </when> <when test='dto.acb21a == "4"'> AND (BCC21B BETWEEN 3000 AND 4499 OR BCC21A BETWEEN 3000 AND 4499) </when> <when test='dto.acb21a == "5"'> AND (BCC21B BETWEEN 4500 AND 5999 OR BCC21A BETWEEN 4500 AND 5999) </when> <when test='dto.acb21a == "6"'> AND (BCC21B BETWEEN 6000 AND 7999 OR BCC21A BETWEEN 6000 AND 7999) </when> <when test='dto.acb21a == "7"'> AND (BCC21B BETWEEN 8000 AND 9999 OR BCC21A BETWEEN 8000 AND 9999) </when> <when test='dto.acb21a == "8"'> AND (BCC21B BETWEEN 10000 AND 14999 OR BCC21A BETWEEN 10000 AND 14999) </when> <when test='dto.acb21a == "9"'> AND (BCC21B >= 15000 OR BCC21A >= 15000) </when> </choose> </if>

关键点说明

  1. 字符串判断优化
    StringUtils.isNotBlank方法会检查字符串是否为null、空字符串或仅包含空白字符,比手动判断更可靠。

  2. 动态 SQL 逻辑清晰
    使用<choose><when>标签实现多条件分支,逻辑清晰且易于维护。

  3. 依赖引入
    确保项目中已引入org.apache.commons.lang3依赖,例如 Maven 配置:

    <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.12.0</version> </dependency>

适用场景

此方案适用于以下情况:

  • 需要严格判断字符串参数是否有效。
  • 动态 SQL 中需根据参数值实现多分支条件逻辑。
  • 避免因参数为空或空白导致 SQL 拼接异常。

通过这种方法,可以显著提升 MyBatis 动态 SQL 的健壮性和可读性。

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

PdfiumViewer:高性能.NET PDF查看器完全指南

PdfiumViewer&#xff1a;高性能.NET PDF查看器完全指南 【免费下载链接】PdfiumViewer PDF viewer based on Googles PDFium. 项目地址: https://gitcode.com/gh_mirrors/pd/PdfiumViewer 在当今数字化办公环境中&#xff0c;PDF文档已成为信息交流的重要载体。PdfiumV…

作者头像 李华
网站建设 2026/4/18 8:38:18

快速部署wvp-GB28181-pro:打造专业级视频监控平台完整指南

你是否曾经为了搭建一个企业级视频监控系统而头疼不已&#xff1f;面对海康、大华等不同品牌设备&#xff0c;如何实现统一管理&#xff1f;今天&#xff0c;我将为你揭秘一个基于GB28181标准的开源解决方案——wvp-GB28181-pro视频监控平台。 【免费下载链接】wvp-GB28181-pro…

作者头像 李华
网站建设 2026/4/18 9:21:00

色彩工程的演进:从RGB到Oklab的现代化之路

在数字色彩处理的发展历程中&#xff0c;我们见证了一场从简单通道混合到感知均匀空间的深刻变革。早期的RGB色彩空间虽然直接映射硬件显示机制&#xff0c;却在色彩感知层面存在显著缺陷。当开发者试图在红色与蓝色之间创建渐变时&#xff0c;往往会出现非预期的灰紫色过渡&am…

作者头像 李华
网站建设 2026/4/18 9:21:12

打破数字壁垒:dupeGuru如何通过NVDA测试成为视障用户的得力助手

打破数字壁垒&#xff1a;dupeGuru如何通过NVDA测试成为视障用户的得力助手 【免费下载链接】dupeguru Find duplicate files 项目地址: https://gitcode.com/gh_mirrors/du/dupeguru 还在为海量重复文件困扰&#xff0c;却担心屏幕阅读器无法兼容&#xff1f;dupeGuru作…

作者头像 李华
网站建设 2026/4/18 9:22:09

Obsidian Templater插件:重新定义知识管理的自动化边界

Obsidian Templater插件&#xff1a;重新定义知识管理的自动化边界 【免费下载链接】Templater A template plugin for obsidian 项目地址: https://gitcode.com/gh_mirrors/te/Templater 在信息过载的时代&#xff0c;知识工作者面临着一个核心挑战&#xff1a;如何在保…

作者头像 李华
网站建设 2026/4/18 8:44:29

GroundingDINO模型配置文件解析:SwinT与SwinB深度对比与实战选择指南

GroundingDINO模型配置文件解析&#xff1a;SwinT与SwinB深度对比与实战选择指南 【免费下载链接】GroundingDINO 论文 Grounding DINO: 将DINO与基于地面的预训练结合用于开放式目标检测 的官方实现。 项目地址: https://gitcode.com/GitHub_Trending/gr/GroundingDINO …

作者头像 李华