Mysql查询结果乱码

现象:使用mysql执行select命令后查到的结果如果含有汉字时会出现乱码,如下:

在这里插入图片描述

解决方法:

1、使用mysql -u用户名 -p密码命令登录MYSQL

在这里插入图片描述

2、执行show variables like 'character%';获取字符集配置

在这里插入图片描述

3、修改/etc/mysql/my.cnf的文件,加入以下内容并保存

[mysql]
default-character-set=utf8
[mysqld]
character-set-server=utf8
[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
default-character-set = utf8
[mysql.server]
default-character-set = utf8
[client]
default-character-set = utf8

4、使用命令service mysql restart重启MYSQL服务,然后使用show variables like 'character%';再看一次编码,发现已改变

在这里插入图片描述

5、再重新执行select查询发现可以显示中文了

在这里插入图片描述

6、查看字符集的命令

#查看MySQL数据库服务器和数据库字符集
show variables like 'character%';

在这里插入图片描述

#查看表中所有列的字符集
show full columns from tb_name;

在这里插入图片描述

#查看表的字符集
show table status from mysql_db like '%tb_name%'

在这里插入图片描述

#查看mysql所支持的字符集
show charset;

在这里插入图片描述

7、修改字符集的命令

// 修改全局字符集
set character_set_connection=utf8;
set character_set_database=utf8;
set character_set_results=utf8;
set character_set_server=utf8;
set character_set_system=utf8;
set collation_connection=utf8;
set collation_database=utf8;
set collation_server=utf8;

// 修改表的字符集 
ALTER TABLE tb_name CONVERT TO CHARACTER SET utf8;

// 修改字段字符集 
alter table tb_name modify column tb_column varchar(30) character set utf8 not null;
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值