尝试使用 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 代码使用 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中文网其他相关文章!