使用mybatis,写了这样一行代码:
<when test="id == '1'">
AND id = '1'
</when>
结果运行时报出异常:
Caused by: java.lang.NumberFormatException: For input string: "1"
很明显这个异常时数字格式化异常,因为数据表中id字段的类型为varchar(2),实体类中id类型为String,所以开始没有感觉哪里出了问题。后来在网上查找,终于找到原因:
原来'1'在这里被认为了时char类型,而不是String类型,这是OGNL的语法问题。
更改方法:
①把test="id='1'"改成test='id="1"'
②把'1'改成其他字符串,如'111'
经过测试,通过上述方法修改代码之后,不再报错。