MySQL数据库中文变问号'???' 解决

数据库 MySQL
今天遇到了一个问题,后端逻辑处理完存到MySQL数据库里的中文内容都变成问号 ‘???’了。我给大家啰里啰唆,主要是把我遇到的坑记录一下。如果对你有帮助 那我也很开心。

[[192287]]

今天遇到了一个问题,后端逻辑处理完存到MySQL数据库里的中文内容都变成问号 ‘???’了。 第一反应是我数据库的排序规则搞错啦? 马上登上phpadmin看了一眼,没毛病 都是utf8_general_ci,手动修改问号成中文也都正常显示。 这里要说一下另外一个问题,开始没注意这个排序规则,默认的是latin1。导致的问题就是数据表中完全不能显示中文,不是乱码 是直接报错。

好啦,既然不是这个问题,那又是什么呢?

在网上找了一下,问题还挺“普遍的”。大致上就是字符集编码问题,改一下就好了,下面是我找到的解决方式(参考其他答主 因为太零碎了就不一一贴参考链接了 再说我也实在不知道哪个才是原答主【ε=ε=ε=┏(゜ロ゜;)┛】):系统环境是Ubuntu 14.04,Windows请找my.ini。

1.

  1. sudo vi /etc/mysql/my.cnf 

2.在[client]/[mysqld_safe]/[mysql]下面依次加入

  1. default-character-set=utf8  
  2. 在[mysqld]下面加入  
  3. init_connect=’SET collation_connection = utf8_unicode_ci’  
  4. init_connect=’SET NAMES utf8’  
  5. character-set-server=utf8  
  6. collation-server=utf8_unicode_ci  
  7. skip-character-set-client-handshake  

3.重启mysql

  1. sudo /etc/init.d/mysql restart 

按照网上其他答案 这时候应该可以了。但是……

what???我发现并没有什么用呀?!!!

好吧,下面 才是我真正想说的 :

首先第一步,修改这些配置文件的时候,你会发现它们是read only 也就只读的。所以我们理所应当的敲下了下面的命令

  1. sudo chmod -R 777 /ect/MySQL/my.cnf 

(我知道这不是个好习惯,但是真的很多人都这是这么做的-/-)

好的,这个时候终于可以修改my.cnf啦

这个时候,有的同学可以顺利的修改 进行下一步啦。但是!!!以我为代表的另一部分同学就倒霉啦,打开 my.cnf 一看…… what?? 基本就是个空的,毛都没有?!好啦好啦 请坐下,这个时候你要看一看下边是不是有个 include****** 对记住后边的文件 去这些文件里做修改就行啦。其实,你直接把需要修改的内容写在 my.cnf中也是可以的,我就这么干了。

终于到了最后一步,重启完 mysql,又试了一下,还是乱码……

问题出在哪呢?请跟我做:

  1. sudo mysql -u root -q 

回车之后,会有个warning /etc/mysql/my.cnf Ignore

意思是my.cnf被忽略了。它被忽略了 那我们的修改肯定没有用了呀。

其实,我们一开始修改了它的读写权限是 777,所有人都可以读写它。系统认为它不安全,才有了这个warning。

所以再我们修改完之后,要再改一下它的权限,比如 644?

好的 现在重启mysql 再实验一下 没问题啦!!!

ps: 查看mysql 字符集编码命令:

  1. sudo mysql -u root -p 

进入mysql 然后输入命令

  1. show variables like ‘%character%’; 

就可以看到了 没截图 就不放了。

啰里啰唆说了一堆,主要是把我遇到的坑记录一下。如果对你有帮助 那我也很开心。

责任编辑:武晓燕 来源: Linux社区
相关推荐

2009-07-23 16:53:17

ASP.NET中文变问

2010-05-24 11:17:41

MySQL数据库

2011-03-07 16:42:05

MySQL数据库安全

2010-03-11 16:33:07

Python连接数据库

2009-03-24 10:45:39

MySQL5连接超时数据库

2010-06-02 17:06:54

MySQL数据库文件

2010-05-27 18:24:09

MySQL数据库密码

2018-08-01 14:00:49

MySQL数据库PHP

2010-05-28 19:06:40

MySQL

2010-05-11 12:57:45

MySQL数据库编码

2011-03-28 13:11:18

MySQL数据库安全

2011-07-27 16:31:53

MySQL数据库utf8gbk

2009-02-09 12:52:32

文件加密Oracle数据库

2011-03-03 17:56:52

MySQL数据库优化

2011-05-13 09:42:21

2010-05-28 11:22:07

2011-03-08 08:49:55

MySQL优化单机

2009-05-08 09:56:37

MaxDBMySQL数据库管理

2010-06-13 11:29:51

MySQL数据库

2010-05-26 09:44:41

MySQL数据库使用
点赞
收藏

51CTO技术栈公众号