首页 >数据库 >mysql教程 >将表情符号插入 MySQL 时如何修复'字符串值不正确”异常?

将表情符号插入 MySQL 时如何修复'字符串值不正确”异常?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-07 14:36:12956浏览

How to Fix

解决插入表情符号时的错误字符串值异常

尝试使用 JDBC 将包含表情符号字符的字符串插入 MySQL 数据库时,可能会遇到以下异常:

java.sql.SQLException: Incorrect string value: '\xF0\x9F\x91\xBD\xF0\x9F...'

出现这个错误是因为 MySQL 默认的 utf8 字符集只支持 Basic 范围内的字符多语言飞机。要解决此问题,您需要启用对 utf8mb4 字符集的支持,该支持将 utf8 扩展为覆盖 emoji 字符所在的扩展平面。

连接初始化

立即将连接编码设置为 utf8mb4建立连接后:

DriverManager.getConnection("jdbc:mysql://localhost:3306/database", "username", "password").prepareStatement("SET NAMES 'utf8mb4'");

数据库和表修改

将数据库和受影响的表的字符集和排序规则更新为 utf8mb4:

ALTER DATABASE `database` CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
ALTER TABLE `table_name` CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

Java 代码

确保您的 Java 代码使用 utf8mb4 字符集字符串字符编码。例如,使用 Connector/J:

DriverManager.getConnection("jdbc:mysql://localhost:3306/database?characterEncoding=utf8mb4", "username", "password");
// ...
preparedStatement.setString(1, "walmart obama ?"); // Emoji characters should be supported now

按照以下步骤,您可以启用对 utf8mb4 的支持,并解决在将表情符号字符插入 MySQL 数据库时出现错误字符串值的异常。

以上是将表情符号插入 MySQL 时如何修复'字符串值不正确”异常?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn