虚拟主机导入MySQL出现Unknown character set:utf8mb4

maolai 网站建设虚拟主机导入MySQL出现Unknown character set:utf8mb4已关闭评论367阅读模式

前几天进行网站搬家,MySQL导入数据的时候,出现以下错误(没有定义的编码集utf8mb4):

SQL 查询:
/*!40101 SET NAMES utf8mb4 */;
MySQL 返回:文档
#1115 - Unknown character set: 'utf8mb4'

虚拟主机导入MySQL出现Unknown character set:utf8mb4-图片1

问题原因:.sql是从恒创主机导出,然后导入到西部数码。因为恒创虚拟主机配备的MySQL数据库版本是5.6。而西部数码虚拟主机配备的MySQL数据库版本是5.1,不支持utf8mb4字符集。所以出现错误,要将mysql数据库升级到5.5以上版本才支持。

虚拟主机导入MySQL出现Unknown character set:utf8mb4-图片2

如果你用的是西部数码的虚拟主机的,可以在虚拟主机管理--管理--(主机相关服务管理)更换机房--选择mysql5.6版本,系统会自动切换mysql5.6服务器。(西部数码目前很多服务都要收手续费的,如机房更换要20元手续费,感觉有点坑吧)

在阿里虚拟主机通过控制面板的DMS工具导入MySQL出现也出现如下报错(目前阿里云数据库暂时不支持utf8mb4这个字符集):

执行的SQL语句出错:
/*!40101 SET NAMES utf8mb4 */
错误信息:Unknown character set: 'utf8mb4'

虚拟主机导入MySQL出现Unknown character set:utf8mb4-图片3

目前大多数服务器数据库版本都是5.1的,如果你用的是阿里虚拟主机,又的确需要使用utf8mb4字符集,可以购买使用MySQL 5.5以上版本的RDS服务。

另一个解决方法:使用记事本打开.sql文件,通过ctrl+h将该文件的中的CHARSET = utf8mb4全部替换成CHARSET = utf8,将COLLATE = utf8mb4_unicode_ci 全部替换为COLLATE = utf8_general_ci,然后重新导入测试,修改之前建议先对源文件做备份。(建议先将之前导入的部分数据删除,将数据库清空再操作导入。)如果还是失败,只能使用之前你搬家的服务器或升级mysql数据库版本了。

说白了,虚拟主机导入MySQL数据出现以上报错:unknown collation:utf8mb4_unicode_ci,就是mysql版本高低造成的。更多方法欢迎交流分享。

PS:目前多数服务器的数据库mysql5.6可以兼容mysql5.1的,导入一般不会有问题。但版本5.1迁移(导入)到其他版本5.6可能会出错,建议尝试升级更高版本的数据库。

 
maolai
  • 本文由 maolai 发表于 2017年1月7日 19:14:25
  • 转载请务必保留本文链接:http://www.bokequ.com/301.html