MySQL错误Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT)解决方法

现象描述

在执行SQL语句中有比较两个表的字段时,出现Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT)错误。意思是遇到的编码错误。

表a是utf8_unicode_ci,而表b是utf8_general_ci。同样是uft-8编码,不知道这样细分的意义。我的两张表是用Navicat分别从两个xlsx文件中导入的,自动就成了这样。下面说一下解决方法。

方法一:

如果数据已导入,又不想修改,可以改一下SQL语句,让其在比较字符串时先转换一下:

b.* from a,b where a.pid
1
修改后语句:select b.* from a,b where a.pid=CONVERT(b.pid USING utf8) COLLATE utf8_unicode_ci 

两个表的编码一致了,就可以比较了。

方法二:

如果想保持SQL语句不变,且以后可能还会经常处理这类问题,那么,就考虑一步到位,即,把数据库编码设置好,并且把已导入的数据进行转换。

先将编码设置一致:将 表a和表b的 ( collations 或者 校对规则)的编码的方式统一为 utf8_general_ci

然后将已有数据进行转换
alter table b convert to character set utf8 collate utf8_general_ci

另外说一句查看数据库编码的方式:

show variables like 'character%';

从以上信息可知数据库的编码为latin1,需要修改为gbk或者是utf8;其中
character_set_client为客户端编码方式;
character_set_connection为建立连接使用的编码;
character_set_database数据库的编码;
character_set_results结果集的编码;
character_set_server数据库服务器的编码;
只要保证以上四个采用的编码方式一样,就不会出现乱码问题。
另一个查看数据库编码的命令:

show variables like 'character%';


觉得不错的话,支持一根棒棒糖吧 ୧(๑•̀⌄•́๑)૭



wechat pay



alipay

MySQL错误Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT)解决方法
http://yuting0907.github.io/posts/f8627087.html
作者
Echo Yu
发布于
2022年5月27日
许可协议