MySql报 java.sql.SQLException: Incorrect string value 乱码解决方法
文章目录
- MySql报 java.sql.SQLException: Incorrect string value 乱码解决方法
- 修改数据库字符集和排序规则
- 检查数据库字符集和排序规则
- 修改数据库字符集和排序规则(谨慎操作)
- 修改表字符集和列字符集(如果数据库修改后还存在问题)
- 检查和修改JDBC连接字符串中的字符集设置
- 在JDBC连接字符串中指定字符集
- 检查JDBC驱动版本
- 检查数据来源的字符编码
- 检查数据获取过程中的编码
- 在Java代码中进行编码转换(如果必要)
报错如下
- 当
MySQL
报java.sql.SQLException: Incorrect string value
这种乱码相关的错误时,可以尝试以下几种解决方法:
修改数据库字符集和排序规则
检查数据库字符集和排序规则
- 首先,登录到MySQL数据库管理终端。使用以下命令查看当前数据库的字符集和排序规则:
SHOW VARIABLES LIKE 'character_set_database';
SHOW VARIABLES LIKE 'collation_database';
- 如果字符集不是
utf8mb4
(对于包含多种语言字符的情况推荐使用这个字符集),或者排序规则不符合你的需求,可能需要进行修改。
修改数据库字符集和排序规则(谨慎操作)
- 备份你的数据库,因为修改字符集和排序规则可能会影响现有数据。
- 可以使用以下命令修改数据库的字符集和排序规则。例如,将数据库
your_database_name
的字符集修改为utf8mb4
,排序规则修改为utf8mb4_unicode_ci
:
ALTER DATABASE your_database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
修改表字符集和列字符集(如果数据库修改后还存在问题)
- 对于数据库中的每个表,可以使用以下命令修改表的字符集:
ALTER TABLE your_table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
- 对于特定的列(如出现问题的
TEMPLATEDATA
列),如果需要单独修改,可以使用:
ALTER TABLE your_table_name MODIFY TEMPLATEDATA VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
- 这里的
VARCHAR(255)
应该根据列的实际数据类型进行调整。
检查和修改JDBC连接字符串中的字符集设置
在JDBC连接字符串中指定字符集
- 如果是通过
Java
的JDBC
连接到MySQL
数据库,在连接字符串中明确指定字符集可以解决一些编码问题。例如,在使用DriverManager
连接数据库时,连接字符串可以写成:
String url = "jdbc:mysql://localhost:3306/your_database_name?useUnicode=true&characterEncoding=utf8mb4";
Connection conn = DriverManager.getConnection(url, "username", "password");
- 上述代码中,
useUnicode=true&characterEncoding=utf8mb4
这部分参数告诉JDBC驱动以utf8mb4
字符集来处理数据传输。
检查JDBC驱动版本
- 确保你使用的是最新版本的MySQL JDBC驱动。旧版本的驱动可能存在一些字符集处理的问题或者对新的MySQL字符集支持不完善。你可以在项目的依赖管理文件(如Maven的
pom.xml
或Gradle的build.gradle
)中更新驱动版本。 - 例如,在
Maven
中,如果当前使用的是较旧的MySQL JDBC
驱动,可以将以下依赖:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>旧版本号</version>
</dependency>
- 更新为最新版本:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>最新版本号</version>
</dependency>
检查数据来源的字符编码
检查数据获取过程中的编码
- 如果数据是从文件中读取的,检查文件的编码格式。例如,如果是文本文件,可以使用文本编辑器查看文件的编码属性(如
UTF - 8
、GBK
等)。 - 如果数据是从其他系统或接口获取的,确保在接收数据时正确处理了编码。例如,如果是通过网络请求获取的数据,检查请求头中的
Content - Type
字段是否正确指定了字符编码。
在Java代码中进行编码转换(如果必要)
- 如果数据来源的编码与数据库要求的编码不一致,可以在
Java
代码中进行编码转换。例如,如果数据是以ISO - 8859 - 1
编码接收的,而数据库要求utf8mb4
,可以使用以下代码进行转换:
// 假设这是从数据源获取的数据
String dataFromSource = "数据字符串";
try {
byte[] isoBytes = dataFromSource.getBytes("ISO - 8859 - 1");
String utf8mb4Data = new String(isoBytes, "utf8mb4");
// 现在可以将utf8mb4Data插入数据库
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}