Mysql创建视图中文乱码修改docker里的配置

编程入门 行业动态 更新时间:2024-10-27 18:26:37

Mysql创建视图中文<a href=https://www.elefans.com/category/jswz/34/1768993.html style=乱码修改docker里的配置"/>

Mysql创建视图中文乱码修改docker里的配置

问题现象:

创建的视图查询无数据,查看创建语句得知,where条件里的中文变成了“???”。

在客户端里查询字符编码:

show VARIABLES like '%char%';


就是character_set_server导致的,它配置的竟然不是utf8,因为他默认就是这个latin1!
踩坑记录:
我在客户端写了个这个命令:

set  character_set_server ='utf8';

表面上再次查询编码确实是变成utf8了,实际上根本不起作用,重启mysql服务也不会起作用!
解决办法:
我的这个mysql是用docker启动的,所以先登录服务器,找到容器

docker ps -a


温馨提示(踩坑记录):注意要加-a查询所有的容器,要不然如果容器Exited状态就查不到它了,比如:

进入容器里,修改myf文件

备注:Windows系统里的mysql,其配置文件叫做my.ini;Linux系统里的mysql,其配置文件叫做myf,一般存放在 /etc/myf或者/etc/mysql/myf路径下。

docker exec -it 2654b151f48c /bin/bash


踩坑记录:一定要加上-it ,要不然没法进入容器,继续操作可就是服务器上的文件了(我这样干过,还疑惑为啥重启不生效,(ˉ▽ˉ;)…)

修改myf文件,在[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了,服务上创建的视图也没有出现乱码情况:

更多推荐

Mysql创建视图中文乱码修改docker里的配置

本文发布于:2023-12-07 10:03:19,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1670930.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:乱码   视图   中文   Mysql   docker

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!