批量更改mysql字符集

1.修改MySQL服务器字符集

SHOW VARIABLES LIKE '%char%';

character_set_server=utf8mb4

重启服务器参数生效

2.更改所有历史业务表字符集

脚本如下:changeChar.sh

#!/bin/sh

#数据库连接信息
USERBANE='root'
PASSWD='root123'
HOST='127.0.0.1'
PORT='3306'


#查询业务库
mysql -u$USERBANE -p$PASSWD -h$HOST -P$PORT -e "select schema_name from information_schema.schemata where schema_name not in ('mysql','sys','information_schema','performance_schema')" -B > DBName.txt

#批量生成修改字符集脚本并执行
cat DBName.txt | while read line
do
    if [ $line = 'SCHEMA_NAME' ];then
    continue
    fi    
    echo "批量生成连接数据库脚本: "$line
    String='SELECT CONCAT("ALTER TABLE ", TABLE_NAME," CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;") AS SQL1 FROM INFORMATION_SCHEMA.TABLES WHERE  TABLE_TYPE="BASE TABLE" AND TABLE_SCHEMA="'$line'"'
    #echo $String
    mysql -u$USERBANE -p$PASSWD -h$HOST -P$PORT -D $line -e "${String}" -B  > DBName.sql
    sed -i '1d' DBName.sql 
    cat DBName.sql  
    mysql -u$USERBANE -p$PASSWD -h$HOST -P$PORT -D $line < DBName.sql
done

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值