0字符串 if mapper test_mybatis的if判断条件将字符串解析成了数字

在MyBatis中,当在mapper.xml的if条件里使用字符串参数时,可能会遇到将字符串误转为数字的问题,引发NumberFormatException。解决办法包括在字符串后加toString()方法或者调整字符串引用的单双引号。通过这次经验,作者提醒开发者要注意此类细节,避免不必要的错误。
摘要由CSDN通过智能技术生成

mybatis可以帮我们自动映射字段,在mapper.xml文件中,我们可以不用去写jdbcType来明确指定数据类型,它会自动解析成相对应的java数据类型,每次在使用了mybatis-generator之后,出于强迫症,我还主动将默认生成的jdbcType给去掉了,一直没出过问题,今天却碰到了一个问题:

出问题的业务场景中,需要根据不同的角色查询不同的订单数据,所以我就直接将角色ID当做参数传递进来,由于有多个角色的情况,所以直接将角色ID拼接成字符串,并用逗号分隔开。

mapper接口:

List getOwnAssignedOrderNo(@Param("backendId") String backendId, @Param("role") String role);

mapper文件:

AND w.backend_id = #{backendId}

AND w.workflow_type = 'manual_check'

AND w.backend_id = #{backendId}

AND w.workflow_type = 'phone_check'

AND w.backend_id = #{backendId}

AND (w.workflow_type = 'manual_check' OR w.workflow_type = 'phone_check')

大家注意看我这里的写法,算得上是中规中矩,role参数已经明确指定了string类型,而且在if条件中,我并没有什么特殊的写法,结果却悲剧了:

Caused by: org.apache.ibatis.exceptions.PersistenceException:

### Error querying database. Cause: java.lang.NumberFormatException: For input string: "2,3"<

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值