Mysql批量修改排序规则(库、表、字段) 您所在的位置:网站首页 mysql表的排序规则 Mysql批量修改排序规则(库、表、字段)

Mysql批量修改排序规则(库、表、字段)

2023-12-27 10:48| 来源: 网络整理| 查看: 265

前言

起因是因为将之前的数据库下的视图转移到当前数据库下,报错 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 实验室设备网 版权所有