mysql默认字符编码设置教程 my.ini设置字符编码(亲测)

本文介绍了mysql数据库中默认字符编码的设置方法,如何设置与修改mysql默认编码,my.ini设置字符编码的教程,需要的朋友参考下。

本节重点:
mysql基础配置之mysql的默认字符编码的设置(my.ini设置字符编码)

mysql的默认编码是latin1,不支持中文。

怎么修改mysql的默认编码?本文以utf-8默认编码修改为例来介绍。

注意,修改mysql默认编码的方法,要修改的地方非常多,相应的修改方法也很多。

为大家分享一种最简单最彻底的修改mysql默认编码的方法,一起来看看吧。

一、windows系统下面
1、中止mysql服务

2、mysql设置编码命令:

set names 'utf8';

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 '%char%'; 你可以看到全变为 utf8 。

  但是,这只是一种假象

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

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

3、在mysql的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个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一项。保存并关闭.

在data/performance_schema目录下的: db.opt文件:  

default-character-set=utf8
default-collation=utf8_general_ci

4、启动mysql服务,由于数据库在开始配置时,我选择的编码是utf8,所以在这里使用 show variables like '%char%';  结果显示编码均为utf8

mysql> SHOW VARIABLES LIKE '%char%';

  确保所有的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

修改已有表格编码

alter table map_data modify province varchar(32) character set utf8;

  另外注意事项:

  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

转自红黑联盟: http://www.blogjava.net/qileilove/archive/2013/06/14/400541.html


二、linux系统下面(这部分只是转载,没尝试过)
1、中止mysql服务(bin/mysqladmin -u root shutdown)
2、在/etc/下找到my.cnf,如果没有就把mysql的安装目录下的support-files目录下的my-medium.cnf复制到/etc/下并改名为my.cnf即可
3、打开my.cnf以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭
4、启动mysql服务(bin/mysqld_safe &)

提示:当前数据库中已经存在的数据仍保留现有的编码方式,因此需要自行转码。

注意:如果是高版本的mysql中,增加时,
将mysql默认编码修改为utf-8呢?只需在my.ini中的[mysqld]组名的末尾添加:
character-set-server=utf8
即可。

mysqld:unknown variable 'default-character-set=utf8'的错误原因是什么?
因为参数:default-character-set=utf8 在较新版本的mysql 中已移除。
建议高版本的mysql使用”character-set-server“,而不要使用“default-character-set”。


  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值