mysql中文乱码如何解决

本文介绍如何通过配置MySQL数据库使其能够正确存储和显示中文字符,避免出现乱码问题。

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

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

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

 

工具/原料

  • 电脑
  • mysql

方法/步骤

  1. 1

    我们可以先看看自己的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;

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

转载于:https://www.cnblogs.com/taz372436/p/5094913.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值