如何解决使用 MySql 和 Emojis
我正在尝试使用 Slick 将表情符号持久化到 MySQL 表中的一列。
我有一个 my.cnf
配置文件,其中包含以下与字符集相关的设置:
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init-connect='SET NAMES utf8mb4'
我的 jdbc 字符串看起来像这样:
url = "jdbc:mysql://localhost/mydb?useLegacyDatetimeCode=false&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8"
现在起初我不确定 characterEncoding
参数是否只使用“UTF-8”,但是根据我将它与 useUnicode=true
参数结合使用时所读到的内容,它应该工作。
当 Slick 执行以下 sql 时:
insert into `content` (`id`,`title`) values ('f1291f0d-eeee-4379-84ef-5d62e2870407','This is an emoji?')
我收到以下错误:
java.sql.SQLException: Incorrect string value: '\xF0\x9F\x8D\x82 |...' for column 'title' at row 1
我正在使用 MySQL v5.7.26
谁能看到可能遗漏了什么?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。