mysql-MySQL库中乱码怎么解决

问题描述

MySQL库中乱码怎么解决

我把MySQL中配置文件的格式更改了,model也注释了,数据库中的编码格式全部都调成一样的
为什么乱码还是没有解决,急急急,求大神给一些建议,谢谢了!

解决方案

mac下解决MySQL中文乱码的问题
mac 解决MySQL中文乱码的问题
解决MYSQL 中文乱码

解决方案二:

看一下这篇文章mysql中出现乱码的原因及其解决方法

解决方案三:

创建的数据库编码也一致吗?

解决方案四:

  1. 查看MySQL数据库编码

    • SHOW VARIABLES LIKE 'char%';
  2. 编码解释
    • character_set_client:MySQL使用该编码来解读客户端发送过来的数据,例如该编码为UTF8,那么如果客户端发送过来的数据不是UTF8,那么就会出现乱码
    • character_set_results:MySQL会把数据转换成该编码后,再发送给客户端,例如该编码为UTF8,那么如果客户端不使用UTF8来解读,那么就会出现乱码
      其它编码只要支持中文即可,也就是说不能使用latin1
  3. 控制台乱码问题
    • 插入或修改时出现乱码:
      > 这时因为cmd下默认使用GBK,而character_set_client不是GBK的原因。我们只需让这两个编码相同即可。
      > 因为修改cmd的编码不方便,所以我们去设置character_set_client为GBK即可。
    • 查询出的数据为乱码:
      > 这是因为character_set_results不是GBK,而cmd默认使用GBK的原因。我们只需让这两个编码相同即可。
      > 因为修改cmd的编码不方便,所以我们去设置character_set_results为GBK即可。
    • 设置变量的语句:
      > 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即可。

    character_set_client | utf8 --> mysql把我们客户端传递的数据都当成是utf8!一是给它传递utf8,二是如果我们传递的是gbk,那么需要修改这个变量为gbk
    character_set_connection | utf8
    character_set_database | utf8
    character_set_results | utf8 --> mysql发送给客户端的数据都是utf8的。一是客户端用utf8编码,二是如果客户端使用gbk来编码,那么需要修改这个变量为gbk的。
    character_set_server | utf8
    character_set_system | utf8


character_set_client=utf8,无论客户端发送的是什么编码的数据,mysql都当成是utf8的数据!

若客户端发送的是GBK
服务器会当成utf8对待
总结:必然乱码!

处理问题的手段有两种;

让客户端发送utf8的数据(行不通)
把character_set_client修改为gbk
set character_set_client=gbk; --> 只在当前窗口内有效,也就是说,关闭窗口后,再打开,又回到utf8了。

character_set_results=utf8,把数据用什么编码发送给客户端!

若服务器发送给客户端的是utf8的数据
客户端会把它当成gbk,因为我们的小黑屏,只能显示gbk
总结:必然乱码!

处理问题的手段有两种:

让服务器发送gbk的数据:set character_set_results=gbk
让小黑屏使用utf8来解读(行不通)

my.ini
在总配置文件中进行配置,可以一劳永逸

[client]

port=3306

[mysql]

default-character-set=gbk /*它可以一劳永逸!它可以修改三个变量:client、results、connection*/

解决方案五:

my.ini
在总配置文件中进行配置,可以一劳永逸

[client]

port=3306

[mysql]

default-character-set=gbk /*它可以一劳永逸!它可以修改三个变量:client、results、connection*/

时间: 2024-10-03 16:39:52

mysql-MySQL库中乱码怎么解决的相关文章

在ie中用js获取的url不乱码,在谷歌中乱码怎么解决

问题描述 在ie中用js获取的url不乱码,在谷歌中乱码怎么解决 var url = location.search; 这个url乱码 怎么解决,请大神教 解决方案 什么样的乱码? url 编码可不能说是乱码噢 %B9%C8%B8%E8 解决方案二: 包含了中文..如果是utf-8编码,可以decodeURIComponent解码下 alert(decodeURIComponent('%E4%B8%AD%E5%9B%BD')) 解决方案三: decodeURIComponent解码 解决方案四:

MySQL命令行出现乱码如何解决

环境:MySQL Sever 5.1 + MySQL命令行工具 问题:使用命令行查询数据库里的数据出现乱码. 解决: set names utf8; --则等同于 set character_set_client=utf8; set character_set_results=utf8; set character_set_connection=utf8; 如果仍出现乱码 执行set names gbk;或者set names gb2312; 查看本栏目更多精彩内容:http://www.bia

mysql query browser中文乱码的解决方法_Mysql

我也一一试过,结果是:中文乱码问题没解决,mysql服务却不能启动了, 汗颜了,还是自己动手解决吧,我这里也截图了,方便参观.我用的是appserv服务包,相信很大一部分同学都在使用这个或是在使用wamp包,很简单,在安装mysql目录下,找到my.ini配置文件: 重启MYSQL服务和apache服务就可以了.

通过命令行导入到mysql数据库时出现乱码的解决方法_Mysql

解决方案: 打开sql文件,在SQL文件第一行加入如下内容 /*!40101 SET NAMES utf8 */; 将SQL文件另存为UTF-8 NO BOM格式 通过ftp上传sql文件,放在根目录下就可以了 进入你的cPanel, 看到cron jobs 这个图标,点击进去,然后选Advanced (Unix Style) 因为只需要运行一次,所以Minute, Hour, Day, Month 都填入准备运行的具体时间,留两分钟余量就行(如果虚拟主机不在本地,可以在FTP上查看一下主机时间

MYSQL数库中的MyISAM如何转化为InnoDB

http://dev.mysql.com/doc/refman/5.6/en/converting-tables-to-innodb.html 查出所有表的信息, 显示为MyISAM为MyISAM引擎 SELECT TABLE_NAME, ENGINE FROM information_schema.TABLES where TABLE_SCHEMA = 'dbname'; 第二步就是转化MyISAM, 成为InnoDB引擎 ALTER TABLE tablename ENGINE=InnoDB

poi 3.7 的导入到excel中乱码怎么解决?

问题描述 就是从jsp表单上获取的数据,在servlet中导出到excel表格中,是中文的是就出现了乱码?这个这么解决呀,我用的是poi3.7版本的,求大神帮忙啊! 解决方案 解决方案二:,转到excel之后就变这样的乱码了,poi3.2之前还可以用setEncoding来设置字符编码,但是这个版本不支持了,有知道的吗?解决方案三:同样有方法设置google一下把LZ解决方案四:servlet读取到之后现在控制台输出一下,看是否是在控制台乱码的..解决方案五:嗯,解决问题了!解决方案六:请问楼主

MySQL导入导出数据出现乱码的解决办法

  在mysql导入导出数据时经常出现中文乱码的问题,大多是因类导入导出时编码设置不一致所引起的.本文介绍了不同平台下的编码转换方法,供大家参考. 在linux系统中默认的是utf8编码,而windows是gbk编码,如果在这二个系统间导入未经指定编码的数据,就会出现乱码. 首先,确定导出数据的编码格式,使用mysqldump的时候需要加上--default-character-set=utf8, 例如: mysqldump -uroot -p --default-character-set=u

快速解决PHP+MYSQL 出现乱码的解决方法

在mysql_connect后面加一句SET NAMES UTF8,即可使得UTF8的数据库消除乱码,对于GBK的数据库则使用SET NAMES GBK,代码如下:  代码如下 复制代码 1 $mysql_mylink = mysql_connect($mysql_host, $mysql_user, $mysql_pass); 2 mysql_query("SET NAMES 'GBK'"); 数据库字符集为utf-8 连接语句用这个    代码如下 复制代码 1 mysql_que

使用php 5时MySQL返回乱码的解决办法

在使用 PHP 5 中,通过 MySQL 查询得到的值全部成为 '???????',原来是字符集设错了. 我在安装 MySQL 5 时,已经选择默认字符集为 gb2312,但还是返回乱码,解决的办法是在连接 MySQL 服务器后,调用一个与所设字符集相同的 "set names X" 语句(X 为你所设的字符集).下面是我的连接函数: function sql_connect() { global $MYSQL_HOST, $MYSQL_USER, $MYSQL_PASSWORD, $