批量修改表中字段的排序规则

sql命令

修改字段的
===
SELECT
    CONCAT(
    'alter table `',
    table_name,
    '` modify `',
    column_name,
    '` ',
    data_type,
    ( CASE WHEN data_type like '%text%' THEN ' ' ELSE CONCAT ( '(', character_maximum_length, ') ' ) END ),
    'character set utf8mb4 collate utf8mb4_bin',
    ( 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
    table_schema = zhegnsn
    AND collation_name = 'utf8mb4_general_ci';

===============================
修改表的
===

SELECT
    CONCAT( 'ALTER TABLE ', TABLE_SCHEMA, '.', TABLE_NAME, ' COLLATE=utf8mb4_bin;' ) 'sql' 
FROM
    information_schema.`TABLES` 
WHERE
    table_schema = zhegnsn AND table_collation = 'utf8mb4_general_ci';

posted @   zheng-sn  阅读(99)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端
点击右上角即可分享
微信分享提示