Mysql批量修改排序规则(库、表、字段) | 您所在的位置:网站首页 › mysql表的排序规则 › Mysql批量修改排序规则(库、表、字段) |
前言
起因是因为将之前的数据库下的视图转移到当前数据库下,报错 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 |
CopyRight 2018-2019 实验室设备网 版权所有 |