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

数据库中的字段总会有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的作用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值