mybatis 报错:Cause: java.lang.NumberFormatException: For input string

博客作者在排查数据库查询错误时,发现异常源于mapper文件中对name字段的条件判断。原本的条件语句使用了双引号导致了NumberFormatException。修改为单引号后问题解决,提示我们注意单双引号在编程中的不同作用。此问题的解决为今后处理类似问题提供了新思路。

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

Cause: java.lang.NumberFormatException: For input string

异常提示

Error querying database. Cause: java.lang.NumberFormatException: For input string: “李四”
Cause: java.lang.NumberFormatException: For input string: “李四”

异常来源

我找了很久,一行一行注释debug,最后才发现是mapper文件里的if条件判断

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

异常解决

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

我不是很明白为什么换一下就不会报错了,不过倒是有了一条新的思路,以后可以考虑考虑单双引号的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值