mysql的collation
2015-09-11 14:21
831 查看
mysql的collation大致的意思就是字符序。首先字符本来是不分大小的,那么对字符的>, = , < 操作就需要有个字符序的规则。
collation做的就是这个事情,你可以对表进行字符序的设置,也可以单独对某个字段进行字符序的设置。一个字符类型,它的字符序有多个,比如:
下面是UTF8对应的字符序。
mysql的字符序遵从命名惯例。以_ci(表示大小写不敏感),以_cs(表示大小写敏感),以_bin(表示用编码值进行比较)。比如:
这个表下面的两个sql会出现同样的结果
如果改成下面的定义:
那么两个sql结果就会不一样了
所以,如果对字符大小敏感的话,最好将数据库中默认的utf8_general_ci设置为utf8_bin。
collation做的就是这个事情,你可以对表进行字符序的设置,也可以单独对某个字段进行字符序的设置。一个字符类型,它的字符序有多个,比如:
下面是UTF8对应的字符序。
utf8_general_ci utf8 33 Yes Yes 1 utf8_bin utf8 83 Yes 1 utf8_unicode_ci utf8 192 Yes 8 utf8_icelandic_ci utf8 193 Yes 8 utf8_latvian_ci utf8 194 Yes 8 utf8_romanian_ci utf8 195 Yes 8 utf8_slovenian_ci utf8 196 Yes 8 utf8_polish_ci utf8 197 Yes 8 utf8_estonian_ci utf8 198 Yes 8 utf8_spanish_ci utf8 199 Yes 8 utf8_swedish_ci utf8 200 Yes 8 utf8_turkish_ci utf8 201 Yes 8 utf8_czech_ci utf8 202 Yes 8 utf8_danish_ci utf8 203 Yes 8 utf8_lithuanian_ci utf8 204 Yes 8 utf8_slovak_ci utf8 205 Yes 8 utf8_spanish2_ci utf8 206 Yes 8 utf8_roman_ci utf8 207 Yes 8 utf8_persian_ci utf8 208 Yes 8 utf8_esperanto_ci utf8 209 Yes 8 utf8_hungarian_ci utf8 210 Yes 8 utf8_sinhala_ci utf8 211 Yes 8 utf8_german2_ci utf8 212 Yes 8 utf8_croatian_ci utf8 213 Yes 8 utf8_unicode_520_ci utf8 214 Yes 8 utf8_vietnamese_ci utf8 215 Yes 8 utf8_general_mysql500_ci utf8 223 Yes 1
mysql的字符序遵从命名惯例。以_ci(表示大小写不敏感),以_cs(表示大小写敏感),以_bin(表示用编码值进行比较)。比如:
CREATE TABLE `issue_message` ( `id` int(11) NOT NULL AUTO_INCREMENT, `content` varchar(255) NOT NULL, PRIMARY KEY (`id`), ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
这个表下面的两个sql会出现同样的结果
select * from issue_message where content = 'Yes' select * from issue_message where content = 'yes'
如果改成下面的定义:
CREATE TABLE `issue_message` ( `id` int(11) NOT NULL AUTO_INCREMENT, `content` varchar(255) NOT NULL COLLATE utf8_bin, PRIMARY KEY (`id`), ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
那么两个sql结果就会不一样了
所以,如果对字符大小敏感的话,最好将数据库中默认的utf8_general_ci设置为utf8_bin。
相关文章推荐
- MySQL manager or server PID file could not be found!
- Mysql慢查询日志
- mysql 性能分析及explain分析
- mysql 按年度、季度、月度、周、日SQL统计查询
- MySQL 性能比较测试:MySQL 5.6 GA -vs- MySQL 5.5
- MySQL通用优化技巧
- MySQL通用优化技巧
- mysql中如何判断 一个数据表是否已经存在
- MySQL用户、[表库字段]权限、管理及查询缓存详解
- MySQL数据类型
- 使用MySQL的jdbcutils配置多个数据源
- MySQL Study之--MySQL InnoDB存储引擎的参数详解及优化
- [MySQL FAQ]系列 — 从MyISAM转到InnoDB需要注意什么
- MySQL之—checking for termcap functions library... configure: error: No curses/termcap library found解决
- MySQL常见的存储引擎讲解
- 获取mysql 所有数据类型列表
- [MySQL FAQ]系列 — MySQL无法启动例一
- [MySQL FAQ]系列 — 打开general log到底影响多大
- 关于MySQL的SLEEP(N)函数
- show status和show variables区别解析