-- 修改数据表的默认字符集和排序规则,并同时转换已有数据,注意是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;
....
Logo

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

更多推荐