使用Mybatis过程中出现NumberFormatException异常

在完善业务代码的时候,出现了NumberFormatException异常

我们先来看看NumberFormatException的定义:

NumberFormatException是Java编程语言中的一个异常类型,用于指示当一个方法需要一个数值类型的参数,但传递的字符串无法正确转换为相应的数值类型时发生的异常。通常发生在使用像Integer.parseInt()或Double.parseDouble()等方法将字符串转换为整数或浮点数时,如果字符串包含无效的字符(如字母、符号等),就会抛出NumberFormatException异常。这个异常通常用于在程序中处理输入数据的错误格式或无效输入。

看下报错原因:

但是我的代码中name为字符串,怎么会出现转换数值类型呢?

经过查找后发现Mapper的xml文件中写动态SQL时出现了错误:判断空字符串时,单引号内不能有空格。因为当你使用 <if> 标签来进行条件判断时,name != ' ’ 这个条件会被解释为:如果 name 不等于空格字符,则执行下面的SQL语句。

将代码

<where>
    <if test="name != null and name != ' ' ">
        name like concat('%',#{name},'%')
    </if>
</where>

改为单引号内无空格即可解决问题

<where>
    <if test="name != null and name != '' ">
        name like concat('%',#{name},'%')
    </if>
</where>

这样,当 name 不为空字符串时,才会执行相应的SQL语句,而不会因为错误的单引号使用导致异常发生。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值