【MySQL错误解决】ERROR 1273 (HY000): Unknown collation: ‘utf8‘ 错误的解决办法

一、前言:

今天把本地数据库导出的sql文件上传到服务器上的数据库的时候,出现了以下的错误。
改错误之处我的文件再导入到数据库的时候,出现字符集不一样的错误。

二、问题产生的原因

这是数据库编码的问题,查了网上的一些资料,出现这个问题的原因在于,wordpress4.2版本之后升级了数据库,如果数据库是mysql5.5以上的互相导入没有问题,如果老网站是mysql5.5的,导入新网站是mysql5.5版本以下的,就会出现这个问题。
在这里插入图片描述

三、问题的解决办法:
1、替换代码

从老的数据库中导出的数据库文件,用vscode等代码编辑器打开。
查找:utf8mb4_unicode_ci,全部替换为:utf8_general_ci
查找:utf8mb4 全部替换为 utf8

补充:vscode替换内容的快捷键为crtl+h

在这里插入图片描述

2、替换字符集

1、通过下面的语句查看当前数据库的编码格式

SHOW VARIABLES LIKE 'character%';

2、然后把 'character_set_server '的编码格式修改为uft8,其它不同的也是,得到下面图片一样的之后,导出来的sql文件就能正确的执行了。

SET character_set_server = "utf8"

在这里插入图片描述

三、问题的分析:

通过导入和修改sql文件的过程中发现,有些文件能够导入并且不报字符集的错误。之后经过对比数据库中表的格式,以及sql文件中出现不符合要求的字符集。发现出现 utf8mb4 格式的字符集的地方是再 varchar 出现的地方,如果只有一些表能够导入,那么说明这些表中不存在 varchar 类型。

  • 13
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值