官方给定的命令行启动mysql容器时,指定字符集的方法无效。但可以通过自定义配置文件实现。
解决方案:
[mysqld] character-set-server = utf8mb4 [client] default-character-set = utf8mb4 [mysql] default-character-set = utf8mb4
docker run \ --name mysql \ -v /path/to/character_set.cnf:/etc/mysql/conf.d \ -e mysql_root_password=my-secret-pw \ -d mysql:tag
进入容器并查看字符集:
show variables like '%char%';
输出结果:
+--------------------------+--------------------------------+ | Variable_name | Value | +--------------------------+--------------------------------+ | character_set_client | utf8mb4 | | character_set_connection | utf8mb4 | | character_set_database | utf8mb4 | | character_set_filesystem | binary | | character_set_results | utf8mb4 | | character_set_server | utf8mb4 | | character_set_system | utf8mb3 | | character_sets_dir | /usr/share/mysql-8.0/charsets/ | +--------------------------+--------------------------------+
以上方法可正确设置字符集。
此外,还可以参考mysql文档“设置字符集”。
以上就是Docker启动MySQL容器时,如何自定义配置字符集?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号