在完善业务代码的时候,出现了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语句,而不会因为错误的单引号使用导致异常发生。