Mybatis java.lang.NumberFormatException: For input string: "1,2" 问题处理

简介: 【8月更文挑战第9天】Mybatis java.lang.NumberFormatException: For input string: "1,2" 问题处理

问题背景

今天在开发过程中,项目请求报了一个错,错误信息【java.lang.NumberFormatException: For input string: "1,2"】,最初看到这个报错还挺奇怪的,在Mybatis xml 中比较值双方都是字符串,但是为什么会出现一个字符串强转数值类型的报错。后来查找了相关文档,找到了具体原因,那么由于之前未曾遇到类似情况,这里便记录一下问题解决方案。

问题分析

报错位置 Mybatis xml 代码如下,Mybatis 在进行参数 == 比较时,会将常量类型的 '1' 强转为数值类型进行比较,而 params.selectParam 的参数内容是 String 类型,这样导致 Mybatis 比较失败,当遇到 '1,2' 时,则会直接报错 java.lang.NumberFormatException: For input string: "1,2"  ,强转数值类型失败

<choose>
            <when test="params.selectParam == '1'">
                GROUP BY t2.channel_type
            </when>
            <when test="params.selectParam == '2'">
                GROUP BY t3.dept_id
            </when>
            <when test="params.selectParam == '1,2'">
                GROUP BY t2.channel_type,t3.dept_id
            </when>
            <otherwise>
                GROUP BY t2.channel_type
            </otherwise>
        </choose>

问题处理

找到问题了,那么此时就有两种解决方案:

一种是将常量类型的 '1' 通过 .toString() 转为 String 类型,这样就可以与 params.selectParam 的参数内容是 String 类型的内容进行正常比较了

<choose>
    <when test="params.selectParam == '1'.toString()">
      GROUP BY t2.channel_type
    </when>
    <when test="params.selectParam == '2'.toString()">
      GROUP BY t3.dept_id
    </when>
    <when test="params.selectParam == '1,2'.toString()">
      GROUP BY t2.channel_type,t3.dept_id
    </when>
    <otherwise>
      GROUP BY t2.channel_type
    </otherwise>
</choose>

另一种方案就是修改 test="params.selectParam == '1'"  的 "" 变 '' ,而内部常量值的 ''  变成 "",处理后就是这样了

<choose>
    <when test='params.selectParam == "1"'>
      GROUP BY t2.channel_type
    </when>
    <when test='params.selectParam == "2"'>
      GROUP BY t3.dept_id
    </when>
    <when test='params.selectParam == "1,2"'>
      GROUP BY t2.channel_type,t3.dept_id
    </when>
    <otherwise>
      GROUP BY t2.channel_type
    </otherwise>
</choose>

这种方案也是可行的,亲测有效,大家遇到这样的问题也可以采用上述两种方案中的一种,不过个人推荐使用第一种方案,代码比较清晰可见。采用第二种方案的话,对于后期维护人员可能会不太容易注意到这 "" 和  '' 的差异。

相关文章
|
1月前
|
Java 索引
java基础(13)String类
本文介绍了Java中String类的多种操作方法,包括字符串拼接、获取长度、去除空格、替换、截取、分割、比较和查找字符等。
34 0
java基础(13)String类
|
2月前
|
Kubernetes jenkins 持续交付
从代码到k8s部署应有尽有系列-java源码之String详解
本文详细介绍了一个基于 `gitlab + jenkins + harbor + k8s` 的自动化部署环境搭建流程。其中,`gitlab` 用于代码托管和 CI,`jenkins` 负责 CD 发布,`harbor` 作为镜像仓库,而 `k8s` 则用于运行服务。文章具体介绍了每项工具的部署步骤,并提供了详细的配置信息和示例代码。此外,还特别指出中间件(如 MySQL、Redis 等)应部署在 K8s 之外,以确保服务稳定性和独立性。通过本文,读者可以学习如何在本地环境中搭建一套完整的自动化部署系统。
65 0
|
10天前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
36 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
2天前
|
安全 Java 测试技术
Java零基础-StringBuffer 类详解
【10月更文挑战第9天】Java零基础教学篇,手把手实践教学!
9 2
|
14天前
|
IDE Java 开发工具
Java“未封闭的 String 表达式”怎么解决
要解决Java中的“未封闭的 String 表示”问题,需检查并修正字符串字面量,确保每个字符串被正确地用双引号括起来。若字符串跨越多行,可使用字符串连接操作符(+)或引入文本块(JDK 13 及以上版本)。这能帮助避免语法错误,并使代码更整洁易读。
|
12天前
|
存储 安全 Java
【一步一步了解Java系列】:认识String类
【一步一步了解Java系列】:认识String类
21 2
|
1月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
|
1月前
|
存储 安全 Java
Java——String类详解
String 是 Java 中的一个类,用于表示字符串,属于引用数据类型。字符串可以通过多种方式定义,如直接赋值、创建对象、传入 char 或 byte 类型数组。直接赋值会将字符串存储在串池中,复用相同的字符串以节省内存。String 类提供了丰富的方法,如比较(equals() 和 compareTo())、查找(charAt() 和 indexOf())、转换(valueOf() 和 format())、拆分(split())和截取(substring())。此外,还介绍了 StringBuilder 和 StringJoiner 类,前者用于高效拼接字符串,后者用于按指定格式拼接字符串
42 1
Java——String类详解
|
1月前
|
安全 Java
Java StringBuffer 和 StringBuilder 类详解
在 Java 中,`StringBuffer` 和 `StringBuilder` 用于操作可变字符串,支持拼接、插入、删除等功能。两者的主要区别在于线程安全性和性能:`StringBuffer` 线程安全但较慢,适用于多线程环境;`StringBuilder` 非线程安全但更快,适合单线程环境。选择合适的类取决于具体的应用场景和性能需求。通常,在不需要线程安全的情况下,推荐使用 `StringBuilder` 以获得更好的性能。
|
1月前
|
Java 索引
Java String 类详解
Java 中的 `String` 类用于表示不可变的字符序列,是 Java 标准库 `java.lang` 包的一部分。字符串对象一旦创建,其内容不可更改,修改会生成新对象。