关于在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 即可。
愿你眼中有光芒,活成你想要的模样
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· 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+树更适合作为索引的结构以及索引原理