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>

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

相关文章
|
10天前
|
存储 JavaScript Java
Java 中的 String Pool 简介
本文介绍了 Java 中 String 对象及其存储机制 String Pool 的基本概念,包括字符串引用、构造方法中的内存分配、字符串文字与对象的区别、手工引用、垃圾清理、性能优化,以及 Java 9 中的压缩字符串特性。文章详细解析了 String 对象的初始化、内存使用及优化方法,帮助开发者更好地理解和使用 Java 中的字符串。
Java 中的 String Pool 简介
|
16天前
|
缓存 安全 Java
java 为什么 String 在 java 中是不可变的?
本文探讨了Java中String为何设计为不可变类型,从字符串池的高效利用、哈希码缓存、支持其他对象的安全使用、增强安全性以及线程安全等方面阐述了不可变性的优势。文中还通过具体代码示例解释了这些优点的实际应用。
java 为什么 String 在 java 中是不可变的?
|
2月前
|
Java 测试技术 开发者
Java零基础-indexOf(String str)详解!
【10月更文挑战第14天】Java零基础教学篇,手把手实践教学!
122 65
|
27天前
|
JSON Java 关系型数据库
Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
在Java中,使用mybatis-plus更新实体类对象到mysql,其中一个字段对应数据库中json数据类型,更新时报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
41 4
Java更新数据库报错:Data truncation: Cannot create a JSON value from a string with CHARACTER SET 'binary'.
|
10天前
|
存储 Java
Java 11 的String是如何优化存储的?
本文介绍了Java中字符串存储优化的原理和实现。通过判断字符串是否全为拉丁字符,使用`byte`代替`char`存储,以节省空间。具体实现涉及`compress`和`toBytes`方法,前者用于尝试压缩字符串,后者则按常规方式存储。代码示例展示了如何根据配置决定使用哪种存储方式。
|
26天前
|
Java
在Java中如何将基本数据类型转换为String
在Java中,可使用多种方法将基本数据类型(如int、char等)转换为String:1. 使用String.valueOf()方法;2. 利用+运算符与空字符串连接;3. 对于数字类型,也可使用Integer.toString()等特定类型的方法。这些方法简单高效,适用于不同场景。
54 7
|
2月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
145 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
2月前
|
Java 测试技术 开发者
Java零基础-indexOf(String str)详解!
【10月更文挑战第13天】Java零基础教学篇,手把手实践教学!
57 1
|
2月前
|
安全 Java 测试技术
Java零基础-StringBuffer 类详解
【10月更文挑战第9天】Java零基础教学篇,手把手实践教学!
49 2
|
2月前
|
IDE Java 开发工具
Java“未封闭的 String 表达式”怎么解决
要解决Java中的“未封闭的 String 表示”问题,需检查并修正字符串字面量,确保每个字符串被正确地用双引号括起来。若字符串跨越多行,可使用字符串连接操作符(+)或引入文本块(JDK 13 及以上版本)。这能帮助避免语法错误,并使代码更整洁易读。
109 7
下一篇
DataWorks