千家信息网

mysql表中文乱码的解决方法

发表于:2024-11-24 作者:千家信息网编辑
千家信息网最后更新 2024年11月24日,这篇文章给大家分享的是有关mysql表中文乱码的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。我们可以先看看自己的mysql数据库,中文是否乱码。登录数据库,再带的
千家信息网最后更新 2024年11月24日mysql表中文乱码的解决方法

这篇文章给大家分享的是有关mysql表中文乱码的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。

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

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


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

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

输入 SHOW VARIABLES LIKE 'character%';

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

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

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

在my.ini中:

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

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

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

重启mysql数据库。

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

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

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

查看各变量的值;

SHOW VARIABLES LIKE 'character%';

或者

status

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


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

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

感谢各位的阅读!关于mysql表中文乱码的解决方法就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

0