博客
关于我
MySQL设置真正的UTF-8
阅读量:199 次
发布时间:2019-02-28

本文共 795 字,大约阅读时间需要 2 分钟。

MariaDB中存储UTF-8字符串时出现了一个奇怪的错误:“Incorrect string value: ‘😃 …’ for column ‘summary’ at row 1”。尽管我使用了UTF-8编码的客户端、服务器以及数据库,保存的字符串“? …”也是合法的UTF-8字符,但问题仍然存在。

问题的根源在于MySQL的“utf8”编码实际上并非真正的UTF-8。与真正的UTF-8相比,“utf8”只支持每个字符最多三个字节,而UTF-8支持每个字符最多四个字节。因此,为了避免类似的问题,应该改用MySQL的“utf8mb4”编码。

以下是修复和优化数据库的步骤:

  • 修改默认编码:

    • 打开/etc/my.cnf文件,找到或添加以下配置:
      [client]default-character-set = utf8mb4[mysql]default-character-set = utf8mb4[mysqld]character-set-client-handshake = FALSEcharacter-set-server = utf8mb4collation-server = utf8mb4_unicode_ci
  • 验证设置:

    • 运行以下MySQL命令,确认编码设置已正确应用:
      mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character_set%';
  • 修复和优化所有表:

    • 使用mysqlcheck命令一次性完成:
      mysqlcheck -u root -p --auto-repair --optimize --all-databases
    • 这将根据设置自动修复和优化所有数据库中的表。
  • 请注意:在MySQL中,永远不要使用“utf8”编码。如果您仍然遇到类似问题,请确保数据库和客户端都使用UTF-8mb4编码。

    转载地址:http://qpai.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现获取本机系统版本(附完整源码)
    查看>>
    Objective-C实现解密藏头诗(附完整源码)
    查看>>
    Objective-C实现醉汉随机行走问题(附完整源码)
    查看>>
    Objective-C实现重载[ ](附完整源码)
    查看>>
    Objective-C实现随机图生成器算法(附完整源码)
    查看>>
    Objective-C实现高斯消元法(附完整源码)
    查看>>
    Objective-C实现高斯滤波GaussianBlur函数用法(附完整源码)
    查看>>
    Objective-C语法之代码块(block)的使用
    查看>>
    Objenesis创建类的实例
    查看>>
    ObsoleteAttribute 可适用于除程序集、模块、参数或返回值以外的所有程序元素。 将元素标记为过时可以通知用户:该元素在产品的未来版本中将被移除。...
    查看>>
    OC Xcode快捷键
    查看>>
    OC 内存管理黄金法则
    查看>>
    OfficeWeb365 SaveDraw 文件上传漏洞复现
    查看>>
    office中的所有content type
    查看>>
    office之Excel 你会用 Ctrl + E 吗?
    查看>>
    OGG初始化之使用数据库实用程序加载数据
    查看>>
    ogg参数解析
    查看>>
    ognl详解
    查看>>
    Oil Deposits
    查看>>
    OJ中处理超大数据的方法
    查看>>