MyBatis中@Param所修饰的属性为Integer值为0导致动态SQL失效问题

本文探讨了在使用MyBatis框架时,动态SQL处理Integer类型0值的问题。当DAO层方法接收参数为0时,MyBatis会将其视为null或空字符串,导致动态SQL条件失效。通过添加特定条件orstate==0,解决了查询语句无法正确执行的问题。建议在设计时避免使用0作为特殊状态标识。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据库中的字段总会有visible字段来让我们的数据进行软删除,当加入业务流程后,这个visible和业务流程控制中的state(当前业务状态)产生一定的数据冗余,所以我们将visible加入到state中。

但是今天写一个接口时产生了一个问题

dao层的方法

List<CommandCheckListVO> selectByProjectId(@Param("projectId") Long projectId, @Param("state") Integer state);

mapper

<if test="state != null and state != ''">
    AND c.state=#{state}
</if>

当Integer为0时,我发现并没有执行语句,有点神奇,于是我增加了一个条件

<if test="state != null and state != '' or state == 0">
    AND c.state=#{state}
</if>

添加了 or state == 0 语句后,发现可以正常查询了。

我大概猜想时MyBatis中@Param所对应的属性为Integer时,并且当这个属性的值为0时,那么MyBatis就会把这个属性改为空字符串,导致我的动态SQL那里判断成功。

因此建议大家在设计时还是要去使用0,使用其他的数字来代替0的作用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值