Bootstrap

# MySql字符集报错

MySql报 java.sql.SQLException: Incorrect string value 乱码解决方法

报错如下
在这里插入图片描述

  • MySQLjava.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连接字符串中指定字符集

  • 如果是通过JavaJDBC连接到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 - 8GBK等)。
  • 如果数据是从其他系统或接口获取的,确保在接收数据时正确处理了编码。例如,如果是通过网络请求获取的数据,检查请求头中的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();
}
;