关于在Mybatis使用Integer与''进行比较的坑

前段时间遇到一个bug,就是修改某一个integer类型的值的时候,除了修改为0 其他的值都可以进行修改。只要想把这个字段改成0 就似乎没有走update这个字段的语句。(前段时间比较忙也就没有记下这个笔记)

相信很多朋友在使用Mybatis的时候都会去使用通用一点的insert或者update语句,类似加入以下这种判断来进行复用。

<if test="age!= null and age!= ''">
    age=#{age,jdbcType=INTEGER}, 
</if>

也就是只有“age”有有效值的时候才会进入set语句,但是在对于Integer类型下的判断就会有一定的影响。

经过我的测试发现mybatis会将Integer值的0等于空字符串''

例如传入的num的值为0,if标签里面一样写

num != null and num != ''

当num的值为0 ,mybatis会当做0等于空串,也就不会进入此if里面的代码块。

比如update语句,如果传进来的值为0那么这个字段就不会被update掉。

也就是说在对Integer类型的值进行判断的时候,只需要加入!= null 即可。

posted @   乖怪丶  阅读(613)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2020-07-30 详解Redis中两种持久化机制RDB和AOF(面试常问,工作常用)
2020-07-30 分析为什么B+树更适合作为索引的结构以及索引原理
欢迎这位客官来到《关于在Mybatis使用Integer与''进行比较的坑 - 乖怪丶 - 博客园》
点击右上角即可分享
微信分享提示