修改 Docker 容器中 MySQL 8.0 默认编码为 utf8mb4_unicode_ci

修改 MySQL 8.0 默认编码为 utf8mb4_unicode_ci

要修改 Docker 容器中 MySQL 8.0 的默认字符集和排序规则为 utf8mb4_unicode_ci,您需要修改 MySQL 的配置文件并重启服务。以下是详细步骤:

直接修改容器内的配置文件

1. 进入容器

bash 复制代码
docker exec -it d510807d0e64 bash

2. 安装文本编辑器

bash 复制代码
apt update
apt install nano -y

3. 编辑 MySQL 配置文件

bash 复制代码
nano /etc/mysql/my.cnf

4. 添加以下内容

ini 复制代码
[mysqld]
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect = 'SET NAMES utf8mb4'

[client]
default-character-set = utf8mb4

[mysql]
default-character-set = utf8mb4

5. 保存并退出编辑器

Ctrl+O 保存,Ctrl+X 退出

6. 重启 MySQL 服务

bash 复制代码
service mysql restart

7. 验证设置

bash 复制代码
mysql -uroot -p -e "SHOW VARIABLES LIKE 'character_set_%'; SHOW VARIABLES LIKE 'collation_%';"
相关推荐
❀͜͡傀儡师1 小时前
Docker部署WebDB数据库开发环境
docker·容器·数据库开发
南山nash1 小时前
企业级docker镜像仓库harbor安装与使用
运维·docker·容器·镜像仓库
m0_485614672 小时前
Linux--Docker网络管理
linux·docker·eureka
zhcf2 小时前
【MySQL】聚簇索引与非聚簇索引
数据库·mysql
姓蔡小朋友3 小时前
MySQL事务、InnoDB存储引擎
java·数据库·mysql
拾荒的小海螺3 小时前
MySQL:死锁问题分析与解决方案
数据库·mysql
Knight_AL3 小时前
Docker 中的端口映射原理:为什么 Nginx 要 `listen 80`,而不是“随便写端口”
nginx·docker·容器
小波小波轩然大波4 小时前
docker总结
网络·docker·容器
qq_2153978974 小时前
内网穿透服务 frps
运维·docker·容器
镜花水月linyi5 小时前
MySQL与Redis缓存一致性方案
redis·后端·mysql