本文介绍了mysql数据库中默认字符编码的设置方法,如何设置与修改mysql默认编码,my.ini设置字符编码的教程,须要的朋友参考下。php
本节重点:
mysql基础配置之mysql的默认字符编码的设置(my.ini设置字符编码)html
mysql的默认编码是latin1,不支持中文。
怎么修改mysql的默认编码?本文以utf-8默认编码修改成例来介绍。java
注意,修改mysql默认编码的方法,要修改的地方很是多,相应的修改方法也不少。mysql
为你们分享一种最简单最完全的修改mysql默认编码的方法,一块儿来看看吧。linux
1、windows系统下面
一、停止mysql服务sql
二、mysql设置编码命令:数据库
set names 'utf8';
windows
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 。jsp
可是,这只是一种假象编码
此种方式只在当前状态下有效,当重启数据库服务后失效。
因此若是想要不出现乱码只有修改my.ini文件,
三、在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四、启动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;
另外注意事项:
一、建表时加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 |
二、网页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
2、linux系统下面(这部分只是转载,没尝试过)
一、停止mysql服务(bin/mysqladmin -u root shutdown)
二、在/etc/下找到my.cnf,若是没有就把mysql的安装目录下的support-files目录下的my-medium.cnf复制到/etc/下并更名为my.cnf便可
三、打开my.cnf之后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭
四、启动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”。