Typecho报错Database Query Error解决办法-Emoji表情原因

Typecho 默认不支持 Emoji 表情,插入emoji表情竟然 Database Query Error 报错。 Emoji 是一种在 Unicode 位于u1F601-u1F64F区段的字符。超出了目前常用的 UTF-8 字符集的编码范围u0000-uFFFF。 在 MySQL 中,UTF-8 只支持最多 3 个字节,而 Emoji 是 4 个字节。所以评论中带有 Emoji 表情才会报错。我们只需简单两步即可让 typecho 支持 emoji 表情评论,只要将默认的数据库编码 utf8 修改为 utf8mb4 即可。

部署简介

  1. phpMyAdmin数据库修改编码
  2. typecho根目录修改配置文件(新版略过)

部署实操

phpMyAdmin数据库修改编码:

🎯使用数据库管理工具,找到表 typecho_XXX 的 text 字段,将该字段的编码改为`utf8mb4_general_ci`,例如评论不能使用就找到 `typecho_comments`等等
Snipaste_2023-09-28_18-46-36

全局插入emoji表情运行以下代码:

alter table typecho_comments convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_contents convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_fields convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_metas convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_options convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_relationships convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_users convert to character set utf8mb4 collate utf8mb4_general_ci;

typecho根目录修改配置文件:

🎯打开网站根目录数据库配置文件 `config.inc.php` 将 charset 的值由 `utf8`改为 `utf8mb4`
/** 定义数据库参数 */
$db = new Typecho_Db('Pdo_Mysql', 'echo_');
$db->addServer(array (
  'host' => 'localhost',
  'user' => 'echo',
  'password' => 'password',
  'charset' => 'utf8mb4', //修改这一参数
  'port' => '3306',
  'database' => 'echo',
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db);

修改好后保存即可。


参考文档

  1. 解决Typecho带有Emoji表情Database Query Error报错的处理方法!-星泽V社
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值