当我创建一个数据库时,我被要求选择默认排序,当我创建一个表时,我被要求选择排序。utf8_general_ci 还是...拉丁语...?区分哪一个是正确的依据是什么?
问问题
6118 次
1 回答
13
排序规则确定字符的排序顺序,它是一组用于比较字符集中字符的规则。任何给定的字符集总是至少有一个排序规则。排序规则名称ci、cs和bin的结尾分别表示不区分大小写、区分大小写和二进制。类似的二进制排序规则utf8_bin
通常也区分大小写,因为它根据字符串的数值进行二进制字符串比较。
这意味着如果要进行不区分大小写的选择查询,其中 a 和 A 没有区别,则应使用以 ci 结尾的排序规则。如果要进行区分大小写的查询,其中 a 和 A 不同,则应使用以 cs 或 bin 结尾的排序规则。
如果没有选择,则应用标准级别。MySQL 中有各种级别的排序规则,例如可以显示为
mysql> show variables like '%collation%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | utf8_general_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
于 2012-04-05T15:52:46.667 回答