MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)

2025-08-11 22:50

本文主要是介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)》本文给大家介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式,本文给大家介绍的非常详细,对大家的学习或...

orderNo != null 这种非字符串类型的判断,也能用 Java 静态方法来替代,比如用 Hutool 的 ObjectUtil.isNotNull()ObjectUtil.isNotEmpty()

我帮你把 字符串StrUtil.isNotBlank()非字符串ObjectUtil.isNotNull() 的完整 MyBATis updateById 版本写好,这样判断逻辑会很统一。

完整 Hutool 写法版本

<update id="updateById" parameterType="com.example.NursingProject">
    UPDATE nursing_project
    <set>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(name)">
            name = #{name},
        </if>
        <if test="@cn.hutool.core.util.ObjectUtil@isNotNull(orderNo)">
            order_no = #{orderNo},
        </if>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(unit)">
            unit = #{unit},
        </if>
        <if test="@cn.hutool.core.util.ObjectUtil@isNotNull(price)">
            price = #{price},
        </if>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(image)">
            image = #{image},
        </if>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(nursingRequirement)">
            nursing_requirement = #{nursingRequirement},
        </if>
        <if test="@cn.hutool.core.util.ObjectUtil@isNotNull(status)">
            status = #{status},
        </if>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(createBy)">
            create_by = #{createBy},
        </if>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(updateBy)">
            update_by = #{updateBy},
        </if>
        <if test="@cn.hutool.core.util.StrUtil@isNotBlank(remark)">
            remark = #{remark},
        </if>
        <if test="@cn.hutool.core.util.ObjectUtil@isNotNull(updateTime)">
            update_time = #{updateTime},
        </if>
    </set>
    WHERE id = #{id}
</update>

对比优化

原本 MyBatis 写法

<if test=www.chinasem.cn"orderNo != null">...</if>

需要区分字符串、数字、对象分别写不同条件。

现在 Hutool 写法

字符串StrUtil.isNotBlank()(避免空格也被当作有效值)

数字/对象ObjectUtil.isNotNull()(仅判断 null,不管 0/false)

这样代码风格统一,可读性也更好。

这个现象其实是 MyBatis + OGNL 的自动类型推断 惹的祸。

你这里:

<if test="@cn.hutool.core.util.ObjectUtil@isNotNull(price)">
    pricehttp://www.chinasem.cn = #{price},
</if>
<if test="@cn.hutool.core.util.ObjectUtpythonil@javascriptisNotNull(status)">
    status = #{status},
</if>

表面上看用的都是同一个 ObjectUtil.isNotNull(),但实际上 pricestatus 的运行时类型不一样:

字段Java 类型jsON 传值类型MyBatis 解析时的实际类型
priceBigDecimal50java.math.BigDecimal
statusInteger1java.lang.Long

为什么status变成Long?

MyBatis 在 JSON 反序列化(或者参数绑定)时,如果是整数值但没有显式指定类型,很多情况下会用 Long 表示(尤其是 Map 或动态 SQL 场景中)。
ObjectUtil.isNotNull(1L) 本身没问题,但在 OGNL 调用静态方法时,有些版本的 MyBatis/OGNL 会先尝试做类型转换(尤其是如果方法签名有重载或匹配不明确时),于是会触发 "Unable to convert type java.lang.Long to java.lang.CharSequence" 这种异常。

为什么 price 没事?

BigDecimal 类型在 OGNL 里不会被误判去做字符串转换,因为它本来就不是 CharSequence,且 ObjectUtil.isNotNull() 的签名 isNotNull(Object) 匹配得很干脆,没有触发额外的类型推断。

怎么解决?

最稳妥的方式就是 不要用静态方法去判断 null,直接用 OGNL 原生的 null 判断:

<if test="price != null">
    price = #{price},
</if>
<if test="status != null">
    status = #{status},
</if>

这样不涉及静态方法匹配,就不会出现 LongCharSequence 的问题。

如果你一定要用 ObjectUtil.isNotNull

<if test="@cn.hutool.core.util.ObjectUtil@isNotNull((Object)status)">
    status = #{status},
</if>

(Object) 是为了让 OGNL 不去尝试把 Long 当作别的类型匹配。

如果单纯比较性能,原生 != null 判断 会明显比 StrUtil.isNotBlank() 快。

原因很简单:

判断方式逻辑性能分析
!= null直接用 OGNL 判断对象是否为 null,属于一次简单的引用比较O(1) 操作,几乎没有额外开销
StrUtil.isNotBlank()Hutool 工具方法,需要静态方法调用 + 类型检查 + 遍历字符串判断空格至少多了方法调用开销 + 字符遍历(字符串越长耗时越多)

举个例子(粗略对比执行步骤):

1.!= null

  • MyBatis OGNL:取值
  • JVM:引用地址是否为 null → true/false
  • 总耗时 ≈ 一次内存地址比较

2.StrUtil.isNotBlank()

  • MyBatis OGNL:加载 StrUtil
  • JVM:调用静态方法
  • 方法内部:
    • 判断对象是否为 null
    • 调用 String.lenpythongth()
    • 遍历每个字符判断是否为空格字符
  • 总耗时 ≈ 多次方法调用 + 字符遍历

结论

  • 非字符串类型!= null 是最优方案(少步骤、无额外逻辑)
  • 字符串类型 → 如果需要判断空字符串和全空格情况,那必须用 isNotBlank()(功能多,但慢一点)
  • 如果字符串允许空格或空值存储,不做空格判断,用 != null 会快很多

建议:

  • 数值、日期、枚举 → 全部用 != null
  • 字符串 → 如果必须去掉空格判断为空,才用 isNotBlank();否则也用 != null

到此这篇关于MyBatis的XML中字符串类型判空与非字符串类型判空处理方式的文章就介绍到这了,更多相关MyBatis xml字符串类型判空内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155679

相关文章

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理

Python中经纬度距离计算的实现方式

《Python中经纬度距离计算的实现方式》文章介绍Python中计算经纬度距离的方法及中国加密坐标系转换工具,主要方法包括geopy(Vincenty/Karney)、Haversine、pyproj... 目录一、基本方法1. 使用geopy库(推荐)2. 手动实现 Haversine 公式3. 使用py

Mybatis-Plus 3.5.12 分页拦截器消失的问题及快速解决方法

《Mybatis-Plus3.5.12分页拦截器消失的问题及快速解决方法》作为Java开发者,我们都爱用Mybatis-Plus简化CRUD操作,尤其是它的分页功能,几行代码就能搞定复杂的分页查询... 目录一、问题场景:分页拦截器突然 “失踪”二、问题根源:依赖拆分惹的祸三、解决办法:添加扩展依赖四、分页

MySQL中处理数据的并发一致性的实现示例

《MySQL中处理数据的并发一致性的实现示例》在MySQL中处理数据的并发一致性是确保多个用户或应用程序同时访问和修改数据库时,不会导致数据冲突、数据丢失或数据不一致,MySQL通过事务和锁机制来管理... 目录一、事务(Transactions)1. 事务控制语句二、锁(Locks)1. 锁类型2. 锁粒

MyBatis流式查询两种实现方式

《MyBatis流式查询两种实现方式》本文详解MyBatis流式查询,通过ResultHandler和Cursor实现边读边处理,避免内存溢出,ResultHandler逐条回调,Cursor支持迭代... 目录MyBATis 流式查询详解:ResultHandler 与 Cursor1. 什么是流式查询?

mybatis用拦截器实现字段加解密全过程

《mybatis用拦截器实现字段加解密全过程》本文通过自定义注解和MyBatis拦截器实现敏感信息加密,处理Parameter和ResultSet,确保数据库存储安全且查询结果解密可用... 目录前言拦截器的使用总结前言根据公司业务需要,灵活对客户敏感信息进行加解密,这里采用myBATis拦截器进行简单实

java实现多数据源切换方式

《java实现多数据源切换方式》本文介绍实现多数据源切换的四步方法:导入依赖、配置文件、启动类注解、使用@DS标记mapper和服务层,通过注解实现数据源动态切换,适用于实际开发中的多数据源场景... 目录一、导入依赖二、配置文件三、在启动类上配置四、在需要切换数据源的类上、方法上使用@DS注解结论一、导入

更改linux系统的默认Python版本方式

《更改linux系统的默认Python版本方式》通过删除原Python软链接并创建指向python3.6的新链接,可切换系统默认Python版本,需注意版本冲突、环境混乱及维护问题,建议使用pyenv... 目录更改系统的默认python版本软链接软链接的特点创建软链接的命令使用场景注意事项总结更改系统的默

Linux升级或者切换python版本实现方式

《Linux升级或者切换python版本实现方式》本文介绍在Ubuntu/Debian系统升级Python至3.11或更高版本的方法,通过查看版本列表并选择新版本进行全局修改,需注意自动与手动模式的选... 目录升级系统python版本 (适用于全局修改)对于Ubuntu/Debian系统安装后,验证Pyt

C#之枚举类型与随机数详解

《C#之枚举类型与随机数详解》文章讲解了枚举类型的定义与使用方法,包括在main外部声明枚举,用于表示游戏状态和周几状态,枚举值默认从0开始递增,也可手动设置初始值以生成随机数... 目录枚举类型1.定义枚举类型(main外)2.使用生成随机数总结枚举类型1.定义枚举类型(main外)enum 类型名字