登录  /  注册
MySQL中文乱码如何解决?
黄舟
发布: 2017-08-02 16:23:56
原创
1552人浏览过

mysql数据库越来越受大家的欢迎了。

中国人往数据库里存数据,总的也不会少了中文,可mysql存中文默认会乱码。

这里我们需要来做一些配置,让它不再是“存进去是中文,查出来是各种问号”了。

1.我们可以先看看自己的mysql数据库,中文是否乱码。

登录数据库,再带的test数据库中,创建一张表,然后插入中文,查询结果。我们可以看到,中文变成了问号。

show databases;
use test;
create table users(name varchar(50));
insert into users values('张三');
select * from users;
登录后复制

1.png

2.我们来查询一下,各个字符相关的变量的值是什么。

输入 SHOW VARIABLES LIKE 'character%';

我们可以看到 character_set_database的值为latin1。大家的值可能和我的不一定一样,总体来说应该不会是都为utf8。

2.png

3.如果有多处不是utf8,我们需要来修改mysql的配置文件my.ini。

一般位于安装路径根目录,或者安装路径根目录的bin下,或者Linux下/etc/my.cnf。

3.png

4.在my.ini中:

搜索到[client],修改或添加default-character-set=utf8;

搜索到[mysqld],修改或添加character-set-server=utf8;

搜到到[mysql],修改或添加default-character-set=utf8;

4.png


5.重启mysql数据库。

Windows下可以运行services.msc,找到mysql服务,重启;

Linux下,可以/etc/init.d/mysqld restart;

我的是xampp,没有添加服务,直接先点击stop,再start就好了。

5.png


6.查看各变量的值;

SHOW VARIABLES LIKE 'character%';
登录后复制

或者

status
登录后复制

6.png

7.测试修改之后是否仍乱码。

create database baidujingyan;
use baidujingyan;
create table users(name varchar(50));
insert into users values('张三');
select * from users;
登录后复制

可以看到,我们的数据库已经能正常显示中文了。

7.png

注意事项

如果在程序中,还会出现乱码,可以在添加 set names utf8

以上就是MySQL中文乱码如何解决?的详细内容,更多请关注php中文网其它相关文章!

相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 技术文章
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2023 //m.sbmmt.com/ All Rights Reserved | 苏州跃动光标网络科技有限公司 | 苏ICP备2020058653号-1

 | 本站CDN由 数掘科技 提供

登录PHP中文网,和优秀的人一起学习!
全站2000+教程免费学