mysql数据库的数据库表和字段修改字符集和排序规则
本文介绍了如何修改MySQL数据表的字符集和排序规则,并转换已有数据。首先,使用ALTER TABLE语句将表的默认字符集和排序规则修改为utf8mb4和utf8mb4_unicode_ci。接着,通过查询information_schema.COLUMNS表,动态生成修改表中所有字段字符集和排序规则的SQL语句。生成的SQL语句可以批量执行,确保表中所有相关字段的字符集和排序规则一致。此方法适用
·
-- 修改数据表的默认字符集和排序规则,并同时转换已有数据,注意是b不是6
alter table xxx表 convert to character set utf8mb4 collate utf8mb4_unicode_ci;
-- 修改mysql数据表中所有字段的字符集和排序规则
-- 动态生成修改字段的sql语句
select
concat(
'alter table `' ,table_name,
'` modify `' , column_name,
'` ' , column_type,
' character set utf8mb4 collate utf8mb4_unicode_ci;'
) as alter_sql
from
information_schema.`COLUMNS`
where
table_schema = 'xxx数据库名'
and table_name = 'xxxx数据库表名'
and data_type in ('varchar','char','text','tinytext','mediumtext','longtext');
-- 运行上述sql(替换数据库名和表名),获取这个表的所有字段的修改语句
-- 复制结果中的修改语句alter_sql,批量执行生成的sql
如:
alter table `xxx表名` modify `xxx字段名` varchar(50) character set utfmb4 collate utf8mb4_unicode_ci;
....

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。
更多推荐
所有评论(0)