命令行mysql 中文乱码解决

news/2025/2/21 10:41:45/

现象

在IDEA中查询,中文显示正常。IDEA中的jdbc连接字符串是:

jdbc:mysql://172.16.184.13:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8

在这里插入图片描述

但是在命令行中查询则出现中文乱码问题:

select user_name,nick_name,sex from sys_user;

在这里插入图片描述

原因分析

查询编码格式

show variables like'%char%';

在这里插入图片描述
数据库设置的是utf8格式的,但是命令行mysql查的是latin1格式的,所以导致乱码问题的出现。

解决办法

更改results编码格式

set character_set_results=utf8;

在这里插入图片描述
这样问题就解决了。
上面一行就能解决查询乱码的问题了。
为了保险起见,可以把其他的也设置成utf8

set character_set_client=utf8;
set character_set_connection=utf8;
set character_set_database=utf8;
set character_set_results=utf8;

设置完成以后编辑格式就是如下:
在这里插入图片描述
然后我执行了update语句,中文的字段更新也正常了。

永久解决

如果每次都手动执行set character_set_results=utf8;解决乱码问题,太麻烦了。关键是有时会忘记,有一次导数据忘记了,导致插入了好多中文乱码的数据,很麻烦。

解决办法很简单:
在你的电脑(客户端)以下配置文件中~/.my.cnf加入如下内容:

[mysql]
default-character-set=utf8

这样下次运行就不用手动设置编码格式了,直接可以使用。
在这里插入图片描述

参考

《MySQL命令行查询乱码解决方法》
https://www.cnblogs.com/aksir/p/7070493.html


http://www.ppmy.cn/news/701017.html

相关文章

python乱码怎么解决方法_Python 乱码问题解决办法

乱码产生的原因是Python在读取时默认解码方式是用操作系统编码,如果和保存时的编码方式不一样,就会出现乱码 比如以下片段,文件保存格式是utf-8 #codingutf-8 print 是 #输出乱码 因为windows默认的编码方式是GBK,python文件保存时使用了…

Excel打开CSV文档乱码解决办法

背景: 自己接收到了别人传送的CSV文档或者从网上下载的文档,使用自己的电脑office2016软件打开却发现是一堆乱码,根本看不清楚上面要表达什么内容,这时候要怎么办呢,换办公软件吗,完全不用,在这…

windows 乱码问题解决

如果没有出现乱码,千万不要修改【可以根据windows 自带的记事本是否乱码作为参考】 具体路径如下 设置--> 时间和语言-->语言和区域-->管理语言设置找到如下界面,直接取消勾选 重启后可以解决 通过以上方法就可以解决了

Mac电脑 csv中文乱码问题解决

运行启动台打开mac电脑自带的“Automator”,如下图所示设置。 截图: 设置代码为: for f in "$"; doif [ -f "$f" ]; theniconv -s -c -f UTF8 -t GBK "$f" > /tmp/iconv.utf8.gbk.tmpmv /tmp/iconv.utf8…

html是乱码怎么解决,如何解决html乱码问题

在html中,可以通过在head节点加入meta标签,匹配好html文件的编码格式来解决html乱码问题,语法格式“”。 本教程操作环境:windows7系统、HTML5版、Dell G3电脑。 HTML文件乱码一般是因为编码格式不匹配造成的,只要匹配…

Redission的RSemaphore信号量有什么作用?

一、概述: RSemaphore是Redisson基于Redis实现的分布式信号量,用于限制同时访问共享区域的线程数量。与Java的Semaphore相似,RSemaphore也有一个acquire()方法用于获取资源,但在获取资源的顺序上是不可预测的,因此它是…

C#中ref与out语法的使用

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Demo { class Program { private int Add(int x, int y)//值参数 { x x y;//对x进行加y操作 return x;//返回x } private int Add(ref in…