mysql如何批量更改数据库及表字段的字符集?
网友回复
假设我们要修改数据库名为dataBaseName下所有表及表字段的字符集编码,那么sql如下:
一、修改所有表中的varchar和char字段以及排序集(dataBaseName修改为库名)
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 ), ';' ) FROM information_schema. COLUMNS WHERE TABLE_SCHEMA = 'dataBaseName' AND (DATA_TYPE = 'varchar' OR DATA_TYPE = 'char')执行完后将结果复制出来再执行一次sql
二、修改所有表的编码及排序集(dataBaseName修改为库名)
SELECT CONCAT( 'ALTER TABLE ', TABLE_NAME, ' CONVERT TO CHARACTER SET utf8mb4;' ) FROM information_schema. TABLES WHERE TABLE_SCHEMA = 'dataBaseName';执行完后将结果复制出来再执行一次sql
google账号如何更改地区与国家?
为啥我的安卓手机chatgpt app打开报错Something went wrong. You may be connected to a disallowed ISP. If you are us
c#如何修改windows的代理设置?
国内华为andriod安卓苹果ios手机如何使用chatgpt4o的app?
win10中怎么让bat批处理文件打开和关闭代理服务?
win10中怎么让bat批处理文件运行完成后不关闭窗口?
docker启动容器后如何挂载宿主文件并执行命令?
有没有lnmp的docker镜像?
何为超级以太网联盟(UEC)?
如何用go语言写一个加密的socks5代理通讯?