当前位置: 首页 > 面试题库 >

尝试通过JDBC将UTF-8插入MySQL时出现“字符串值错误”的问题?

阙新觉
2023-03-14
问题内容

这是我的连接设置方式:
Connection conn = DriverManager.getConnection(url + dbName + "?useUnicode=true&characterEncoding=utf-8", userName, password);

尝试在表中添加行时出现以下错误:
Incorrect string value: '\xF0\x90\x8D\x83\xF0\x90...' for column 'content' at row 1

我要插入数千条记录,并且当文本包含\ xF0时,总是会出现此错误(即,不正确的字符串值始终以\ xF0开头)。

该列的排序规则是utf8_general_ci。

可能是什么问题呢?


问题答案:

MySQL的utf8许可仅允许使用UTF-8中的3个字节表示的Unicode字符。在这里,您需要一个需要4个字节的字符:\ xF0 \ x90 \
x8D \ x83(U + 10343 GOTHIC LETTER
SAUIL)。

如果您使用MySQL
5.5或更高版本,则可以将列编码从更改utf8utf8mb4。此编码允许存储在UTF-8中占用4个字节的字符。

您可能还需要服务器属性设置character_set_serverutf8mb4MySQL的配置文件中 似乎Connector /
J缺省为3字节Unicode,否则:

例如,要将4字节UTF-8字符集用于Connector /
J,请使用配置MySQL服务器character_set_server=utf8mb4,并保留characterEncodingConnector
/ J连接字符串。然后,Connector / J将自动检测UTF-8设置。



 类似资料:
  • 我的连接是这样设置的: 当tyring向表中添加一行时,我会遇到以下错误: 我正在插入数以千计的记录,当文本包含\xf0(即不正确的字符串值总是以\xf0开头)时,我总是得到这个错误。 列的排序规则是UTF8_GENERAL_CI。

  • 我正在尝试在表a中插入外键(在phpmyadmin中): 将表A添加外键(id_B)引用B(id_B); 但我得到了一个错误: 表A的id_A为主键,表B的id_B为主键。这两个表都使用innoDB作为存储引擎,表A中的id_B列和表B中的id_B列具有相同的类型。 出了什么问题,我该如何解决?

  • 我正在尝试将命令存储在队列中,并在以后从队列中读取它们。我使用这个队列是因为代码需要在Arduino上运行。当访问第一个(或任何)字符时,我得到一个分段错误。我在这里做错了什么? 谢谢你的帮助! PS:这招管用:

  • 新数组列表 我用多头填充这个数组列表。 当我试图将其插入postgresql时,我使用以下方法: 使用JDBC模板。但是当我试图运行这段代码时,它在“ARRAY[?]”上给出了一个错误。但如果temp2是一个单一的数字,比如:1253214,它就可以工作。有人有主意吗? 我的错误是: PreparedStatementCallback;错误的SQL语法[UPDATE pb1plnitm SET p

  • 无法打印出格式错误弹出的结果。 尝试在没有getWaitingTime()和%-20d(最后一个)的情况下执行,它可以工作。 尝试执行1,并用getWaitingTime()替换seqNo,它可以工作。 不确定是什么错误。 它调用toString方法的部分。它从servicelist被称为。 至于错误是: JAVAutil。MissingFormatArgumentException:邮局的格式说