Mybatis Integer类型参数值为0时判断为空、空字符串不通过

根据状态查询是,由于status是Integer类型,所以当前状态为0时,变成了查询了所有的状态信息。

<if test="requestParam.status != null and requestParam.status != ''">
    and s.status = #{requestParam.status}
</if>

原因:

MyBatis因自身原因默认了 Integer类型数据值等于0时 为 ""(空字符串)

解决办法:

1. 某些情况下,可以在Controller处就拦截,并向前台提示,比如:“必须输入有效数字”,不让他再往后传。

2. 将判断条件version != ''删去,不让它判断。

如:

<if test="requestParam.status != null">
    and s.status = #{requestParam.status}
</if>

3. 单独加上当status为0的特殊情况弊端:就是当有哪位仁兄真的用这个方法传了个空字符串,就无法判断。

如:

<if test="requestParam.status != null and requestParam.status != '' or requestParam.status == 0 ">
    and s.status = #{requestParam.status}
</if>

当然,如果想默认输入为0时查询所有(类似于上述问题示例)或者是后面想转为空字符串,

可以不用改,也算是巧用"bug"。

4.最后就是可以将Integer类型转成字符串,也是ok的。

引用\[1\]:在Hibernate中,可以使用if标签来进行条件判断。在if标签中,可以使用!= ''来判断一个字符串是否为空。例如,<if test="status != null and status !=''">and status = #{status}</if>表示当status不为null且不为空字符串,执行and status = #{status}这段SQL语句。引用\[2\]:在Mybatis中,对于参数0的处理有一些特殊情况。当参数Integer类型的0Mybatis会自动将其识别为空字符串。如果想要使Integer类型的0符合条件,可以去掉对字符串判断。另一种解决办法是将参数改为字符串类型,这样既可以避免该问题,也不会漏判字符串的情况。所以,对于Hibernate中的if标签判断字符串的问题,在Mybatis中是不存在的。 #### 引用[.reference_title] - *1* [Hibernate学习笔记之HQL](https://blog.csdn.net/zxy15974062965/article/details/120874862)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Mybtais判断为空](https://blog.csdn.net/weixin_44018338/article/details/123487098)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值