MySQL编码问题

MySQL编码问题

我们都很热爱utf-8,然而总是到处碰壁。


一、修改MySQL编码的方法

(1)方法一:一次性修改

(i)第一步输入:set character_set_client=gbk;
(ii)第二步输入:set character_set_results=gbk;
缺点:只在当前窗口内有效,也就是说,关闭控制台窗口后,再打开,中文又乱码了。


(2)方法二:永久修改(推荐)

(i)第一步,打开文件夹安装了MySQL的路径,我的是E:\Program Files (x86)\MySQL\MySQL Server 5.5
(ii)第二步,找到文件my.ini
(iii)第三步,用记事本打开配置文件,找到如下语句:

[client]
port=3306
[mysql]
default-character-set=utf8

(iv)第四步,把最后一句default-character-set=utf8,修改为default-character-set=gbk,保存
(v)第五步,重新启动SQL服务,使生效。如下:

net stop mysql                    //用来停止服务

net start mysql                    //用来启动服务



-----------------------------------------------------华丽的分割线



二、修改MySQL编码的方法的解释

(1)查看MySQL数据库编码

在控制台输入:
  SHOW VARIABLES LIKE 'char%';可以看到:

| character_set_client     | utf8   
| character_set_connection | utf8 
| character_set_database   | utf8 
| character_set_filesystem  | binary 
| character_set_results    | utf8
| character_set_server     |utf8
| character_set_system     | utf8 
| character_sets_dir      | E:\Program Files (x86)\MySQL\MySQL Server 5.5\share\charsets\

(2)编码解释

(i)character_set_client:MySQL使用该编码来解读客户端发送过来的数据,例如该编码为UTF8,那么如果客户端发送过来的数据不是UTF8,那么就会出现乱码
(ii)character_set_results:MySQL会把数据转换成该编码后,再发送给客户端,例如该编码为UTF8,那么如果客户端不使用UTF8来解读,那么就会出现乱码



(3)控制台乱码问题

(i)插入或修改时出现乱码:
     这时因为cmd下默认使用GBK,而character_set_client不是GBK的原因。我们只需让这两个编码相同即可。

     因为修改cmd的编码不方便,所以我们去设置character_set_client为GBK即可。


  (ii) 查询出的数据为乱码:
     这是因为character_set_results不是GBK,而cmd默认使用GBK的原因。我们只需让这两个编码相同即可。

     因为修改cmd的编码不方便,所以我们去设置character_set_results为GBK即可。


  (iii)设置变量的语句:
    set character_set_client=gbk;
    set character_set_results=gbk;
注意
设置变量只对当前连接有效,当退出窗口后,再次登录mysql,还需要再次设置变量。为了一劳永逸,可以在my.ini中设置:设置default-character-set=gbk即可。

(4) 指定默认编码

我们在安装MySQL时已经指定了默认编码为UTF8,所以我们在创建数据库、创建表时,都无需再次指定编码。为了一劳永逸,可以在my.ini中设置:设置character-set-server=utf8即可。 修改之后,重启SQL服务,SHOW VARIABLES LIKE 'char%', 可以看到,character_set_client 、character_set_connection、character_set_results这三项都变成GBK, 这就成功了!




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值