日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

批量修改MySQL表字符集和排序規(guī)則

 hncdman 2023-07-11 發(fā)布于湖南

取生成修改sql重新運行進(jìn)行修改即可

一、問題

二、修改字符集

三、修改庫字符集和排序規(guī)則

四、修改表和字段字符集以及排序規(guī)則

1、查詢并生成修改語句

2、生成簡潔的修改表以及字段字符集和排序規(guī)則的語句

一、問題

        由于建庫建表指定的數(shù)據(jù)庫字符集和排序規(guī)則,和應(yīng)用需求不一致,導(dǎo)致系統(tǒng)因字符集不一致異常。

二、修改字符集

        該生產(chǎn)庫使用MySQL8.0版本,使用的默認(rèn)字符集為:utf8mb4 ;使用的排序規(guī)則是: utf8mb4_0900_ai_ci。

        通過測試驗證和評估,需要修改該生產(chǎn)庫庫、表和字段的排序規(guī)則為utf8mb4_general_ci和自字符集為utf8mb4。

        查看庫、表以及字段的字符集和排序規(guī)則命令

-- 查看庫、表以及字段的字符集和排序規(guī)則命令

-- 方法一

-- 1、查看指定庫排序規(guī)則和字符集

show create database '庫名字';

-- 2、查看指定表以及排序規(guī)則和字符集

show create table '表明字';

-- 方法二

select * from  information_schema.`TABLES` where TABLE_SCHEMA='庫名字' and tables='表名字'

select * from  information_schema.`COLUMNS` where TABLE_SCHEMA='庫名字' and tables='表名字'

三、修改庫字符集和排序規(guī)則

-- 修改庫的排序規(guī)則和字符集

ALTER database '庫名' DEFAULT CHARSET utf8mb4 COLLATE utf8mb4_general_ci;

四、修改表和字段字符集以及排序規(guī)則

1、查詢并生成修改語句

-- 1、查看需要修改字符集和排序規(guī)則的表

SELECT

    TABLE_SCHEMA AS '數(shù)據(jù)庫',

    TABLE_NAME AS '表',

    TABLE_COLLATION AS '原排序規(guī)則',

    CONCAT('ALTER TABLE ', TABLE_SCHEMA, '.', TABLE_NAME, ' DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;') AS '修正SQL'

FROM

    information_schema.`TABLES`

WHERE

    TABLE_COLLATION ='utf8mb4_0900_ai_ci' AND TABLE_SCHEMA = '庫名字';

-- 2、查看需要修改字符集和排序規(guī)則的字段

SELECT

    TABLE_SCHEMA AS '數(shù)據(jù)庫',

    TABLE_NAME AS '表',

    COLUMN_NAME AS '字段',

    CHARACTER_SET_NAME AS '原字符集',

    COLLATION_NAME AS '原排序規(guī)則',

    CONCAT('ALTER TABLE ', TABLE_SCHEMA, '.', TABLE_NAME, ' MODIFY COLUMN `', COLUMN_NAME, '` ', COLUMN_TYPE, ' CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;') AS '修正SQL'

FROM

    information_schema.`COLUMNS`

WHERE

    CHARACTER_SET_NAME = 'utf8mb4' AND COLLATION_NAME != 'utf8mb4_general_ci' AND TABLE_SCHEMA = '庫名字';

2、生成簡潔的修改表以及字段字符集和排序規(guī)則的語句

-- 1、生成修改表 的字符集和排序規(guī)則的SQL語句

SELECT    CONCAT('ALTER TABLE ', TABLE_SCHEMA, '.', TABLE_NAME, ' DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;') AS '修正SQL'

FROM

    information_schema.`TABLES`

WHERE

    TABLE_COLLATION ='utf8mb4_0900_ai_ci' AND TABLE_SCHEMA = '庫名字';

-- 2、生成修改字段 的字符集和排序規(guī)則的SQL語句

SELECT    CONCAT('ALTER TABLE ', TABLE_SCHEMA, '.', TABLE_NAME, ' MODIFY COLUMN `', COLUMN_NAME, '` ', COLUMN_TYPE, ' CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;') AS '修正SQL'

FROM

    information_schema.`COLUMNS`

WHERE

    CHARACTER_SET_NAME = 'utf8mb4' AND COLLATION_NAME != 'utf8mb4_general_ci' AND TABLE_SCHEMA = '庫名字';

————————————————

版權(quán)聲明:本文為CSDN博主「@土豆」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請附上原文出處鏈接及本聲明。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多