问题现象:
创建的视图查询无数据,查看创建语句得知,where条件里的中文变成了“???”。
在客户端里查询字符编码:
show VARIABLES like '%char%';
就是character_set_server导致的,它配置的竟然不是utf8,因为他默认就是这个latin1!
踩坑记录:
我在客户端写了个这个命令:
set character_set_server ='utf8';
表面上再次查询编码确实是变成utf8了,实际上根本不起作用,重启mysql服务也不会起作用!
解决办法:
我的这个mysql是用docker启动的,所以先登录服务器,找到容器:
docker ps -a
温馨提示(踩坑记录):注意要加-a查询所有的容器,要不然如果容器Exited状态就查不到它了,比如:
进入容器里,修改my.cnf文件
备注:Windows系统里的mysql,其配置文件叫做my.ini;Linux系统里的mysql,其配置文件叫做my.cnf,一般存放在 /etc/my.cnf或者/etc/mysql/my.cnf路径下。
docker exec -it 2654b151f48c /bin/bash
踩坑记录:一定要加上-it ,要不然没法进入容器,继续操作可就是服务器上的文件了(我这样干过,还疑惑为啥重启不生效,(ˉ▽ˉ;)…)
修改my.cnf文件,在[mysqld]下方加上配置:
character_set_server=utf8
init_connect='SET NAMES utf8'
划重点:一定要在[mysqld]下方加,要不然可能不会生效!
原因:配置文件中的启动选项被划分为若干个组,每个组有一个组名,用中括号[]扩起来。
参考文章:mysql配置文件的使用
踩坑记录:
因为容器里没有vim和vi命令,突发奇想使用了echo 命令直接往文件后面追加,也没有注意到没放在[mysqld]组下面,所以重启后配置一直不生效。
使用echo命令的话:
echo "xxx" >> a.txt ——把xxx追加到a.txt文件最后面
echo "xxx" > a.txt ——把xxx覆盖到a.txt文件里
所以最后意识到以后,使用了>才得以纠正。
重启mysql服务
我使用的是docker命令重启的服务,主从服务器分别重启:
再次用客户端查看编码,已经是utf8了,服务上创建的视图也没有出现乱码情况: