问题

mybatis中的动态语句如下:

<if test="rate != null and rate != ''"> and rate = #{rate}</if>

当rate等于0,并且是BigDecimal类型的话,执行sql语句的时候发现rate 字段并没有更新

原因

因为mybatis会自动把BigDecimal类型转为string,即把0变为null。主要是rate != ''这个判断会生效

解决

正确的写法:把rate != ''删掉

<if test="rate != null"> and rate = #{rate}</if>
Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐