Typecho 添加 Emoji 表情报错「解决方案」

Typecho 添加 Emoji 表情报错

文章目录

  • [Typecho 添加 Emoji 表情报错](#Typecho 添加 Emoji 表情报错)
    • 前言
      • [Emoji 表情](#Emoji 表情)
      • [utf8mb4 与 UTF8](#utf8mb4 与 UTF8)
    • 解决方案
      • [[1] 数据库编码更改](#[1] 数据库编码更改)
      • [[2] 数据库配置文件更改](#[2] 数据库配置文件更改)

前言

Typecho 添加 Emoji 表情不支持,报错 Database Query Error


Emoji 表情

Emoji 就是表情符号,来自日语词汇"絵文字"(假名为"えもじ",读音即 emoji),随着技术的发展被使用得越来越广泛。

😀😁😂🤣😃😄😅😆😉😊😋😎😍😘🥰😗🙄🤐😐😪😴

👩👨🧑👧👦🧒👶👵👴👩‍🦳👼🤶👮‍♀️👩‍🏭

🎈🎆🎇🧨✨🎉🎊🎃🎄🎋🎍🎎🎏🎐🎑🧧🎀🎁🎗🎞🎟🎫🎠🎡👟🥾🥿🥌

🍕🍔🍟🌭🍿🥟🍛🍗🚗🚓🚕🚝🚈🚅🚄❤🧡💛✝☦♐♏♎♍

utf8mb4 与 UTF8

utf8mb4 它占用 4 个字节的存储空间,而 utf8 是 3 个字节,这样,用 3 个字节去存储 4 个字节的东西,很明显是存不下的,会报错,所以要用 utf8mb4,并且 utf8mb4 是兼容 utf8 的。

注意:对于 MariaDB 而言貌似 utf8mb4 有一个使用限制,MariaDB 版本必须是 5.5 以上;对于PHP而言,只有在 PHP5.5 以后才支持。

Emoji 表情 是 4 个字节。而我们默认的 Typecho数据库表编码为 UTF-8,这么说就明白了吧 😉?


解决方案

[1] 数据库编码更改

方案 1:如果你正好使用 PhpMyadmin 的话,那么修改起来就比较容易了

进入 PhpMyadmin,选择对应数据库,操作 排序规则 选择 utf8mb4_unicode_ci

修改数据库表排序顺序 UTF8 为 utf8mb4


方案 2

sql 复制代码
alter table typecho_comments convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_contents convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_fields convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_metas convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_options convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_relationships convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_users convert to character set utf8mb4 collate utf8mb4_unicode_ci;

[2] 数据库配置文件更改

修改 Typecho 网站 根目录 数据库配置文件 config.inc.php

php 复制代码
$db->addServer(array (
  'host'      =>  localhost,
  'user'      =>  'youruser',
  'password'  =>  'yourpassword',
  'charset'   =>  'utf8mb4',  // 修改这一行 utf8 -> utf8mb4
  'port'      =>  xxxx,
  'database'  =>  'yourdatabase'
), Typecho_Db::READ | Typecho_Db::WRITE);
相关推荐
思成不止于此6 分钟前
MySQL 查询实战(三):排序与综合练习
数据库·笔记·学习·mysql
茅坑的小石头15 分钟前
数据库表设计,概念模型、逻辑模型、物理模型的区别,目标、主要内容、所处阶段、面向人群,数据库无关性
数据库
tebukaopu14820 分钟前
mysql数据备份还原
数据库·mysql
zyxqyy&∞22 分钟前
mysql代码小练-2
数据库·mysql
JIngJaneIL1 小时前
基于Java非遗传承文化管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
+VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue心理健康管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
only-qi2 小时前
Redis如何应对 Redis 大 Key 问题
数据库·redis·缓存
muxin-始终如一3 小时前
消息丢失场景和解决方案
数据库·中间件·消息丢失
CoderYanger3 小时前
动态规划算法-子序列问题(数组中不连续的一段):28.摆动序列
java·算法·leetcode·动态规划·1024程序员节
老华带你飞5 小时前
旅游|基于Java旅游信息系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·旅游