前言
起因是因为将之前的数据库下的视图转移到当前数据库下,报错 Mysql 报错: `Error 1267 Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci,IMPLICIT) for operation ‘=’
,经查,是转移视图的两个数据库之间的排序规则不一样,一个是utf8mb4_general_ci,另一个是utf8mb4_unicode_ci,做关联查询的时候会报错,这里就需要将另一个数据库的排序编码改成和之前数据库的utf8mb4_general_ci编码一样
解决方法
数据库修复
直接通过navicat编辑数据库即可,选择自己需要的排序规则
数据表修复
#改变表
SELECT TABLE_SCHEMA '数据库',TABLE_NAME '表',TABLE_COLLATION '原排序规则',CONCAT('ALTER TABLE ',TABLE_SCHEMA,'.', TABLE_NAME, ' COLLATE=utf8mb4_general_ci;') '修正SQL'
FROM information_schema.`TABLES`
WHERE TABLE_COLLATION RLIKE 'utf8mb4_unicode_ci'; # 需要修改的排序编码
utf8mb4_unicode_ci 是我原来数据库表的匹配排序规则
utf8mb4_general_ci设置的是替换的排序规则,可以换为需要修正为什么标准
把修正的SQL复制出来运行,字段标准就修复了
字段修复
SELECT
CONCAT('ALTER TABLE `', table_name, '` MODIFY `', column_name, '` ', DATA_TYPE,
'(', CHARACTER_MAXIMUM_LENGTH, ') CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci',
(CASE WHEN IS_NULLABLE = 'NO' THEN ' NOT NULL' ELSE '' END),
(case when IFNULL(column_comment,'')='' then '' else concat(' COMMENT \'' , column_comment ,'\'') end),
';') as `sql`
FROM information_schema.COLUMNS
WHERE 1=1
and TABLE_SCHEMA = 'gxqwanggehua' #要修改的数据库名称
and DATA_TYPE = 'varchar'
and COLLATION_NAME='utf8mb4_unicode_ci' #被改的编码
运行完上面的sql后,下面会生成一些sql,ctrl + A全选后,全部执行即可
参考来源:
https://blog.csdn.net/Teddy_Husky/article/details/112561365
https://blog.csdn.net/ifu25/article/details/120646717