AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 427744
Accepted
Rui F Ribeiro
Rui F Ribeiro
Asked: 2018-03-03 10:37:27 +0800 CST2018-03-03 10:37:27 +0800 CST 2018-03-03 10:37:27 +0800 CST

MySQL:不正确的字符串值

  • 772

我在网页中的某些字符上遇到了一些问题,我们在 UTF8 中经常遇到这些问题。

我正在使用 Debian 9 运行 MySQL 5.7。我的数据库正在使用utf8字符集。

今天在调试一个mysql查询的时候,跑到SHOW WARNINGS;Message字段中看到:

 Incorrect string value: '\xF0\x9D\x8C\x86' for column `xxxx`;

怎么了?

debian mysql
  • 1 1 个回答
  • 628 Views

1 个回答

  • Voted
  1. Best Answer
    Rui F Ribeiro
    2018-03-03T10:37:27+08:002018-03-03T10:37:27+08:00

    最终,通过谷歌搜索错误,我发现了几篇文章,表明在 MySQL 中,utf8字符集是错误的/大脑受损,不应该使用。

    在它的替换中,应该使用utf8mb4字符集来代替。

    在MySQL 中,永远不要使用“utf8”。使用“utf8mb4”

    MySQL 的“utf8”不是 UTF-8。

    “utf8”编码仅支持每个字符三个字节。真正的 UTF-8 编码——包括你在内的每个人都在使用——每个字符最多需要四个字节。

    MySQL 开发人员从未修复过这个错误。他们在 2010 年发布了一个解决方法:一个名为“utf8mb4”的新字符集。

    简而言之:
    - MySQL 的“utf8mb4”表示“UTF-8”。
    - MySQL 的“utf8”表示“专有字符编码”。这种编码不能编码许多 Unicode 字符。

    我将在这里做一个全面的声明:所有当前使用“utf8”的 MySQL 和 MariaDB 用户实际上应该使用“utf8mb4”。没有人应该使用“utf8”。

    从如何在 MySQL 数据库中支持完整的 Unicode

    原来 MySQL 的 utf8 字符集仅部分实现了正确的 UTF-8 编码。它只能存储由一到三个字节组成的 UTF-8 编码符号;不支持占用四个字节的编码符号。

    如上所示,这种行为可能会导致数据丢失,但情况会变得更糟——它可能会导致安全漏洞。以下是一些示例,所有示例都是在发布此文章后发现的:

    • WordPress < 3.6.1 中的 PHP 对象注入漏洞,导致与某些 WordPress 插件结合远程执行代码
    • WordPress 4.1.2 中 Phabricator 存储的 XSS 中的电子邮件身份验证绕过
    • Joomla 中的远程命令执行!内容管理系统

    TL;DR MySQL 的utf8编码名称很尴尬,因为它与正确的 UTF-8 编码不同。它不提供完整的 Unicode 支持,这可能导致数据丢失或安全漏洞。

    • 1

相关问题

  • astyle 不会更改源文件格式

  • 接收有关全新 Debian 的电子邮件

  • Debian Stretch:libgs_plugin_systemd-updates.so 中的 gnome-software 段错误

  • MySQL Select with function IN () with bash array

  • 如何在拼音输入法中输入ü?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve