MySql编码转化问题

转载 2015年11月18日 12:36:38

MySql修改数据库编码为UTF8

 mysql 创建 数据库时指定编码很重要,很多开发者都使用了默认编码,乱码问题可是防不胜防。制定数据库的编码可以很大程度上避免倒入导出带来的乱码问题。

  网页数据一般采用UTF8编码,而数据库默认为latin 。我们可以通过修改数据库默认编码方式为UTF8来减少数据库创建时的设置,也能最大限度的避免因粗心造成的乱码问题。

  我们遵循的标准是,数据库,表,字段和页面或文本的编码要统一起来

  我们可以通过命令查看数据库当前编码:

  mysql> SHOW VARIABLES LIKE 'character%';

  发现很多对应的都是 latin1,我们的目标就是在下次使用此命令时latin1能被UTF8取代。

  第一阶段:

  mysql设置编码命令

SET character_set_client = utf8;
SET character_set_connection = utf8;
SET character_set_database = utf8;
SET character_set_results = utf8;
SET character_set_server = utf8;

  然后 mysql> SHOW VARIABLES LIKE 'character%'; 你可以看到全变为 utf8 。

  但是,这只是一种假象

  此种方式只在当前状态下有效,当重启数据库服务后失效。

  所以如果想要不出现乱码只有修改my.ini文件,

  从my.ini下手(标签下没有的添加,有的修改)

  [client]
  default-character-set=utf8
  [mysql]
  default-character-set=utf8
  [mysqld]
  default-character-set=utf8

  以上3个section都要加default-character-set=utf8,平时我们可能只加了mysqld一项。

  然后重启mysql,执行

  mysql> SHOW VARIABLES LIKE 'character%';

  确保所有的Value项都是utf8即可。

  但是可恶的事情又来了,

  |character_set_client      | utf8                                  |
  | character_set_connection | utf8                                  |
  | character_set_database   | utf8                                  |
  | character_set_filesystem | binary                                |
  | character_set_results    | utf8                                  |
  | character_set_server     | latin1                                |
  | character_set_system     | utf8

  注意  该配置| character_set_server     | latin1 无法设置成UTF8   交互时候仍然会出现乱码。

 第二阶段:找到下面这东东

  X:\%path%\MySQL\MySQL Server 5.0\bin\MySQLInstanceConfig.exe

  重新启动设置,将默认编码设置为utf8.这样就能达到我们所要的效果了。

  mysql> SHOW VARIABLES LIKE 'character%';

  +--------------------------+---------------------------------------------------------+
  | Variable_name            | Value                                                   |
  +--------------------------+---------------------------------------------------------+
  | 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       | C:\Program Files\MySQL\MySQL Server 5.0\share\charsets\ |
  +--------------------------+---------------------------------------------------------+

  8 rows in set

  另外注意事项:

  1、建表时加utf8,表字段的Collation可加可不加,不加时默认是utf8_general_ci了。

CREATE TABLE `tablename4` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`varchar1` varchar(255) DEFAULT NULL,
`varbinary1` varbinary(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

  2、网页xxx.php/jsp保存时选择utf8编码,页头最好加上

  header('conten-type:text/html;charset=utf-8');

  在执行CRUD操作前先执行一下

  mysql_query("set names utf8");

  -------------------------

  连接数据库设置编码

  jdbc:mysql://地址:3306/数据库名?characterEncoding=utf8

  -------------------------

  java中的常用编码UTF-8;GBK;GB2312;ISO-8859-1;

  对应mysql数据库中的编码utf8;gbk;gb2312;latin1


mysql编码问题

  • 2013年06月05日 01:38
  • 19KB
  • 下载

Linux下MySQL5.6的修改字符集编码为UTF8(解决中文乱码问题,亲测可用!)

Linux下MySQL5.6的修改字符集编码为UTF8(解决中文乱码问题) 一、登录MySQL查看用 SHOW VARIABLES LIKE ‘character%’; 下字符集,显示如下: +...

mysql字符编码问题latin1到utf8

测试目的: java从mysql读取数据并打印 测试环境1 a. hadoop集群某节点的环境是utf8,java代码也是utf8编码 b. 需要读取的mysql服,数据库、数据表均是latin1 ...

MySQL编码问题

一、修改MySQL编码的方法 (1)方法一:一次性修改 (i)第一步输入:set character_set_client=gbk; (ii)第二步输入:set character_set_...

Mysql编码问题

原文: http://www.cnblogs.com/csj007523/archive/2008/03/20/1115516.html 人建议,数据库字符集尽量使用utf8(HTML页面对应的是ut...

Windows编码相关知识 & VC与MySQL交互数据乱码问题

字符必须编码后才能被计算机处理。最早的编码是7位的ASCII编码。ASCII码没有办法处理中文、阿拉伯文等复杂的文字。         各个国家为了处理自己的文字,纷纷制定了自己的文字编码规范,其中...
  • dyzhen
  • dyzhen
  • 2011年02月21日 14:14
  • 577

【MySQL】【数据库编码问题】ERROR 1366 (HY000): Incorrect string value: '\xC0\xEE\xC7\xBF' for column

今天在向MySQL数据库中插入数据失败,提示为ERROR 1366 (HY000): Incorrect string value: '\xC0\xEE\xC7\xBF' for column 'SN...

mysql时的编码问题

背景:好久没写程序了,手痒,windows平台下用vs2010+C#+mysql(noinstall版本)+navicat. 出现问题:开始直接在noinstall版本的mysql下面直接启用mys...
  • jo_say
  • jo_say
  • 2015年04月19日 22:08
  • 543

Linux cron执行mysql失败(编码问题)

在接入一个渠道的时候,由于对方不给ROOT权限,也没有MYSQL的最高权限,MYSQL的配置这些已经不受掌控.于是出现了一下问题. 1.首先,为了统计服务器平均在线人数,于是写了个SHELL脚本...

Mac下Mysql数据库编码问题

对于mac系统来说,安装Mysql数据库简单的方式从官网下载一个dmg文件,然后点下一步下一步就OK,所有步骤完成后,Mysql会装在/usr/local/mysql/下,这里的mysql文件夹仅仅是...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MySql编码转化问题
举报原因:
原因补充:

(最多只允许输入30个字)