mysql修改某个库里所有表的字符集,统一字段、表、库的字符集用,解决建表不规范导致的字符集不一致问题

-- 在对应的库创建并执行以下存储过程,可以将库中所有表的字符集转换为指定字符集,如果不指定字符集,则转换为库的默认字符集。
-- 1用法:CALL ResetAllTablesCharsetToDefault('mydb1', ''); 所有表和字段会转换为库的默认字符集
-- 2用法:CALL ResetAllTablesCharsetToDefault('mydb1', 'utf8mb4'); 所有表和字段会转换为utf8mb4字符集
-- 注意:如果更改库的字符集,新建表会使用新的字符集,但是已有表不会自动转换,需要手动转换。

CREATE
DEFINER=`root`@`%` PROCEDURE `ResetAllTablesCharsetToDefault`(IN dbName VARCHAR(64), IN charsetName VARCHAR(64))
BEGIN
    DECLARE
done INT DEFAULT FALSE;
    DECLARE
tableName VARCHAR(64);
    DECLARE
cur CURSOR FOR
SELECT table_name
FROM information_schema.tables
WHERE table_schema = dbName;
DECLARE
CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

    IF
charsetName IS NULL OR charsetName = '' THEN
        SET charsetName = (SELECT default_character_set_name FROM information_schema.SCHEMATA WHERE schema_name = dbName);
END IF;

OPEN cur;

read_loop
: LOOP
        FETCH cur INTO tableName;
        IF
done THEN
            LEAVE read_loop;
END IF;

        SET
@s = CONCAT('ALTER TABLE `', dbName, '`.`', tableName, '` CONVERT TO CHARACTER SET ', charsetName);
PREPARE stmt FROM @s;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;

END LOOP;

CLOSE cur;
END

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值