码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Mysql创建视图中文乱码修改docker里的配置


    问题现象:

    创建的视图查询无数据,查看创建语句得知,where条件里的中文变成了“???”。
    在这里插入图片描述
    在客户端里查询字符编码:

    show VARIABLES like '%char%';
    
    • 1

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

    set  character_set_server ='utf8';
    
    • 1

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

    docker ps -a
    
    • 1

    在这里插入图片描述
    温馨提示(踩坑记录):注意要加-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
    
    • 1

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

    修改my.cnf文件,在[mysqld]下方加上配置:

    character_set_server=utf8
    init_connect='SET NAMES utf8'
    
    • 1
    • 2

    划重点:一定要在[mysqld]下方加,要不然可能不会生效!
    原因:配置文件中的启动选项被划分为若干个组,每个组有一个组名,用中括号[]扩起来。
    参考文章:mysql配置文件的使用

    踩坑记录:
    因为容器里没有vim和vi命令,突发奇想使用了echo 命令直接往文件后面追加,也没有注意到没放在[mysqld]组下面,所以重启后配置一直不生效。

    使用echo命令的话:

    echo "xxx" >> a.txt ——把xxx追加到a.txt文件最后面
    echo "xxx" > a.txt ——把xxx覆盖到a.txt文件里
    
    • 1
    • 2

    所以最后意识到以后,使用了>才得以纠正。

    重启mysql服务
    我使用的是docker命令重启的服务,主从服务器分别重启:
    在这里插入图片描述
    再次用客户端查看编码,已经是utf8了,服务上创建的视图也没有出现乱码情况:
    在这里插入图片描述

  • 相关阅读:
    第二十五章 使用任务管理器(三)
    信息系统工程验收测试内容及费用
    【华为OD机试真题 python】 TLV解析【2022 Q4 | 100分】
    离线数仓搭建_02_服务器配置与数据生产
    C语言内存函数
    systemverilog学习 --- 数组操作(二)
    文字转语音:语音合成(Speech Synthesis) 数组文字循环播放
    短信验证码登录需求的坑点整理
    【unity小技巧】适用于任何 2d 游戏的钥匙门系统和buff系统——UnityEvent的使用
    uniapp如何实现关闭前面指定数目页面
  • 原文地址:https://blog.csdn.net/wysghmbb/article/details/133928370
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号