环境
- 系统:macOS Mojave
- MySQL:5.7.26
解决方案
-
在桌面新建一个名为
my.cnf
的文件- 注意区分mac版mysql与Windows版的mysql配置文件扩展名不同:
mac下: my.cnf
windows下: my.ini
- 注意区分mac版mysql与Windows版的mysql配置文件扩展名不同:
-
用 vscode 打开它,添加如下内容
[mysqld] character-set-server=utf8 [client] default-character-set=utf8 [mysql] default-character-set=utf8
-
打开访达,点击前往文件夹,输入
/etc/
,回车,进入 etc 文件夹 -
将第二步中的文件拷贝到 etc 文件夹下
-
打开终端,进入 etc 文件夹,输入
sudo chmod 664 my.cnf
,更改 my.cnf 文件的权限为 664 -
重启电脑
-
再新建一个数据库,这时显示中文就不会乱码了,也不会无法插入中文了
-
进入mysql环境后,使用
show variables like '%char%;
命令可以发现,编码都变成 utf8 了
- 其它参考文章:https://www.cnblogs.com/1102whw/p/7815466.html
- 不过发现这样仍然没有解决在 datagrip 中使用查询时,起中文别名不显示的问题以及建表时起中文列名不显示的问题,原因可能在这里,不过博主并没有测试过是否可行
- 在 navicat 和终端中使用中文是可以正常显示的