命令行mysql 中文乱码解决

现象

在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

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值