PHP批量修改MySQL数据表字符集为utf8mb4/utf8mb4_unicode_ci

编码大全

可参考我之前的文章:
快速理解ASCII、GBK、Unicode、UTF-8、ANSI

批量修改

注意这是DDL操作,操作过程会锁表(元数据锁),平均1秒能够转码3张表(数据量不大)。

亲测操作过后没有数据异常,推荐执行前备份。

php 复制代码
//接手一些老项目,需要修改编码。
$host = '';
$db   = '';
$user = '';
$pass = '';
$charset = 'utf8mb4';
$collate = 'utf8mb4_unicode_ci';

try {
    $pdo = new PDO("mysql:host=$host;dbname=$db;charset=$charset", $user, $pass);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    // 从information_schema获取所有的表名
    $stmt = $pdo->query("SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_SCHEMA = '$db'");
    $tables = $stmt->fetchAll(PDO::FETCH_COLUMN, 0);

    // 遍历所有的表并修改其编码
    foreach ($tables as $table) {
        $sql = "ALTER TABLE `$table` CONVERT TO CHARACTER SET $charset COLLATE $collate;";
        $pdo->exec($sql);
        echo "{$table}    ====>    {$charset}/{$collate}" . PHP_EOL;
    }

} catch (PDOException $e) {
    die("MySQL连接失败" . $e->getMessage());
}

最后别忘了执行数据库本身的转码操作。

sql 复制代码
ALTER DATABASE my_database CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;
相关推荐
Irene19916 分钟前
SQL示例:外键约束是关系型数据库中用于建立两个表之间链接的一种规则
mysql
HMS工业网络7 分钟前
技术干货:EtherCAT设备ESI(XML)文件中的CompleteAccess关键字有什么作用
xml·运维·服务器
dadaobusi10 分钟前
PCIe的ATS和PRS
java·网络·数据库
汽车仪器仪表相关领域12 分钟前
HORIBA MEXA-584L 全功能汽车排放废气分析仪:便携精准排放检测 + 多参数同步测量 + 国六 / 欧 7 合规适配,汽车检测与调校的黄金标准
服务器·数据库·人工智能·功能测试·汽车·压力测试·可用性测试
TechWayfarer15 分钟前
账号安全实战:基于IP归属地基线的三原则异地登录风控模型
服务器·网络·python·安全·网络安全
Edward1111111119 分钟前
SSL/TSL配置 集群节点间通信加密还有客户端
linux·服务器·ssl
1892280486119 分钟前
NV232固态闪存MT29F32T08GWLBHD6-TES:B
大数据·服务器·人工智能·科技·缓存
qq_3660862223 分钟前
SQL 中 OR 与 UNION ALL选择指南
数据库·sql
正在走向自律29 分钟前
时序数据库技术内幕:从大数据存储模型看工业级时序数据库的设计与落地
大数据·数据库·时序数据库·工业物联网存储·tsfile 存储引擎·大数据时序技术·物联网数据治理
zshs00031 分钟前
从 Raft 到 MySQL:我是怎么推导出半同步复制原理的
数据库·分布式·mysql