- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图使用UTF-8遇到麻烦。
我尝试了很多事情;这是我得到的结果:????
而不是亚洲字符。即使是欧洲文字,我也为Se?or
设置了Señor
。
奇怪的胡言乱语(Mojibake?),例如Señor
或新浪新闻
表示新浪新闻
。
黑钻石,例如Seor。
最终,我陷入了数据丢失或至少被截断的情况:Se
表示Señor
。
即使我看到正确的文本,它也无法正确排序。
我究竟做错了什么?如何修复代码?我可以恢复数据吗?
最佳答案
这个问题困扰着该站点的参与者以及其他许多人。
您列出了CHARACTER SET
故障的五种主要情况。
最佳实践
展望未来,最好使用CHARACTER SET utf8mb4
和COLLATION utf8mb4_unicode_520_ci
。 (管道中有更新版本的Unicode排序规则。)utf8mb4
是utf8
的超集,它处理4字节的utf8代码,Emoji和一些中文需要这些代码。
在MySQL之外,“ UTF-8”是指所有大小的编码,因此实际上与MySQL的utf8mb4
相同,而不是utf8
。
在下文中,我将尝试使用这些拼写和大写字母来区分MySQL内部和外部。
您应该做什么概述
将您的编辑器等设置为UTF-8。
HTML表单应以<form accept-charset="UTF-8">
开头。
将您的字节编码为UTF-8。
建立UTF-8作为客户端使用的编码。
将列/表声明为CHARACTER SET utf8mb4
(检查SHOW CREATE TABLE
。)
HTML开头的<meta charset=UTF-8>
存储的例程获取当前的字符集/排序规则。他们可能需要重建。
UTF-8 all the way through
More details for computer languages(及其后续部分)
测试数据
无法信任使用工具或SELECT
查看数据。
太多这样的客户端,尤其是浏览器,试图补偿不正确的编码,并向您显示正确的文本,即使数据库已损坏。
因此,选择一个包含非英语文本的表和列,然后执行
SELECT col, HEX(col) FROM tbl WHERE ...
20
4x
,
5x
,
6x
或
7x
Cxyy
Dxyy
Exyyzz
F0yyzzww
Se
表示
Señor
):
Se�or
表示
Señor
);
SET NAMES
和
INSERT
的连接(或
SELECT
)不是utf8 / utf8mb4。解决这个问题。
CHARACTER SET utf8
(或utf8mb4)。
SET NAMES
的连接(或
SELECT
)不是utf8 / utf8mb4。解决这个问题。
CHARACTER SET utf8
(或utf8mb4)。
<meta charset=UTF-8>
时,才会出现黑色菱形。
Se?or
表示
Señor
):
CHARACTER SET utf8
(或utf8mb4)。解决这个问题。 (使用
SHOW CREATE TABLE
。)
Señor
的
Señor
):
INSERTing
和
SELECTing
文本时的连接需要指定utf8或utf8mb4。解决这个问题。
CHARACTER SET utf8
(或utf8mb4)。解决这个问题。
<meta charset=UTF-8>
开头。
SELECT .. HEX ..
来确认双重编码。
é should come back C3A9, but instead shows C383C2A9
The Emoji 👽 should come back F09F91BD, but comes back C3B0C5B8E28098C2BD
Señor
一样进行排序。
关于mysql - UTF-8字符有问题;我看到的不是我存储的,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40073387/
如何获取特定 UTF-8 字符串的字节序列?我看到正则表达式引擎中的某些错误仅在某些边缘情况下才会触发,我想确切地知道它正在处理哪些数据。 最佳答案 也许 charToRaw ? > charToRa
考虑一个具有许多变量的 java 程序,其中一些是循环计数器,我希望看到这些变量随时间变化的值,而不是在代码中到处放置 print 语句。 为什么?我认为它可以帮助我轻松调试。 Example- in
有没有办法查看 JavaScript 正在创建的“线程”?例如,如果我有一个附加到 DOM 元素的事件处理程序,我假设 JavaScript 会隐式地创建一个新线程来在后台运行该代码?如果是这样,有没
我正在使用反射 API 来调用类运行时并调用其方法。但我看到 java.lang.reflect.InitationTargetException 异常。 我需要调用一个名为 - TestClass
考虑一个名为 t.cmd 的命令脚本,它只包含以下两行: @exit /b 123 @echo If you see this, THEN EXIT FAILED.. 因此,该脚本只是将脚本执行过程的
我最近一直在努力学习编程语言实用学第 3 版,以了解更多关于语言在底层如何工作的信息,并且通过查看由真正基本的 GCC 编译的 C 代码生成的程序集,我获得了很多进展.我开始对 C 系列的静态语言越来
最简单的制作方法是什么QWebView识别并正确加载网页上的 Flash? 最佳答案 似乎只需两行即可实现(当然,假设目标系统上安装了闪存): QWebSettings *settings = QWe
我想通过编程(使用VBA)访问其他人与我共享的日历。它们在我的Outlook中的“人民日历”下列出。我在网上搜索了此内容,所有建议所做的仅使我感到困惑。如何从“人的日历”中获取共享给我的所有日历的
使用MongoDB Compass,可以看到数据库用户或创建新用户吗? 最佳答案 香港专业教育学院在命令行上使用以下命令进行管理: mongo use (my database name) db.cr
我正在CentOS 7.4.1708(核心),Java(TM)SE运行时环境(内部版本1.8.0_152-b16)上运行eXist-db 3.6.1。我希望能够在person.xml中的最后一个记录之
我需要确认。 客户端 1 在事务内的表中插入行。 客户端 2 使用 SELECT 请求该表。如果在此客户端上隔离级别设置为 READ COMMITTED,您能否确认 SELECT 不会返回客户端 1
我刚刚安装了 python-dev: $ sudo apt-get install python-dev 这样我就可以开始使用 P4Python 了。但是当我尝试导入 P4 时,我得到: Traceb
我正在使用 msys 和 mingw 编译 libtorrent-rasterbar-0.16.16。./configure 运行良好,直到它进入 boost 库检查。我有 boost 1.51,我设
我在 GO 项目的 Travis CI 上有一个奇怪的行为。 [这里] 失败了,提示一个函数只接受 1 个参数并用 2 个参数调用。 src/finances-service/main.go:45:1
这个问题已经有答案了: What are enums and why are they useful? (27 个回答) 已关闭 4 年前。 作为 Java 初学者,我接触到了枚举,这让我对类型声明感
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我正在使用 preactjs 创建我的应用程序。最重要的是,我正在使用剑道网格。在网格内,我想显示一个超链接。如果用户点击链接,它应该改变路线。为了呈现链接,我使用了 preact-router。 这
有没有办法只查看 Node.js 中的函数签名?我知道 fn.toString() 但不需要所有代码,只需要签名。 最佳答案 var source = fn.toString(); var signa
如何设置 vim 以查看我在 ubuntu 上安装的 ruby rvm。 rvm 已安装,ruby 从终端返回。 renshaw@renshaw-TravelMate-5740G:~$ ruby
我试图在我的 Android 应用程序中防止 OutOfMemoryError。我已经阅读了很多帖子,但我仍然无法解决。 该应用程序有后台 Activity ,所以我认为这是主要问题。 OutOfMe
我是一名优秀的程序员,十分优秀!