您的位置:首页 > 数据库 > MySQL

Mysql字符集以及校对规则

2015-07-31 23:13 661 查看
编码:计算机都是二进制存储,因此需要将显示符号转换成二进制数才能存储,每个字符所转换成的二进制数,就是字符编码。

字符集

字符用于显示的抽象符号。字符集是一套字符与字符编码的集合。

常见的字符集编码:

Ascii字符集,GB2312字符集,gbk字符集,latin1字符集,unicode字符集等。

show character set;
可以获得MySQL支持的所有字符集。

修改数据库字符集

alter database liguodong character set utf8;


MySQL可以使用多种字符集保存数据。

MySQL可以针对字段,表,数据库,服务器进行字符集的设置,还可以设定连接字符集(客户端与服务器端交互时)。

编码相关变量的含义:




可以在my.ini中:
character-set-server=utf8
修改服务器的编码设置。

服务器字符集:



连接字符集:



校对规则:

每一套编码字符集都有与之相关的校对规则。校对规则指的是当前字符集内,字符之间的比较关系。

每个字符集都提供一个或多个校对规则。

通常的命名规则是:
字符集_语言名_ci|cs|bin


常见的ci不区分大小写。cs区分大小写,bin字节比较。

查看校对规则指令:

show collation;

show collation like 'gbk%';


在设置字符集的时候,可以设置当前字符集所采用的校对规则。不过不设置校对规则,那么每一个字符集,都有一个默认的校对规则。

以gbk为例,比较chinese_ci,bin之间的区别

create table tab3(
name varchar(10)
) character set gbk collate gbk_chinese_ci;

create table tab4(
name varchar(10)
) character set gbk collate gbk_bin;


默认是gbk_chinese_ci,所以不会显示字符集。

show create table tab3\G
show create table tab4\G







insert into tab3 values('a');
insert into tab3 values('B');
insert into tab3 values('c');
insert into tab4 values('a');
insert into tab4 values('B');
insert into tab4 values('c');




影响数据的保存,字符集。

影像数据的比较,校对集。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: