签到成功

知道了

CNDBA社区CNDBA社区

MySQL 字符集 和 排序规则 说明

2024-04-25 10:14 684 0 转载 MySQL
作者: dave

注:本文由大模型生成http://www.cndba.cn/cndba/dave/article/131536

http://www.cndba.cn/cndba/dave/article/131536

MySQL中的字符集和排序规则是用于定义数据库如何存储、比较和检索字符数据的。字符集决定了数据库可以存储哪些字符,而排序规则则决定了这些字符如何进行比较和排序。

字符集(Character Set)

字符集定义了数据库中可用的字符范围。不同的字符集支持不同的字符和编码方式。

控制参数:

  • character_set_server:服务器级别的默认字符集。
  • character_set_database:数据库级别的默认字符集。
  • character_set_system:系统元数据的字符集,通常不需要修改。
  • character_set_client:客户端发送的SQL语句的字符集。
  • character_set_connection:连接层的字符集,用于客户端和服务器之间的通信。
  • character_set_results:服务器返回给客户端的结果集的字符集。

参数格式:

字符集名称通常是大小写不敏感的,如utf8latin1等。http://www.cndba.cn/cndba/dave/article/131536http://www.cndba.cn/cndba/dave/article/131536http://www.cndba.cn/cndba/dave/article/131536

常用配置值说明:

  • utf8:使用UTF-8编码,支持大部分国际字符。
  • latin1:西欧语言字符集。
  • gbk:简体中文字符集。

排序规则(Collation)

排序规则决定了字符的比较和排序方式。它基于字符集,但提供了更详细的排序和比较规则。http://www.cndba.cn/cndba/dave/article/131536

控制参数:

  • collation_server:服务器级别的默认排序规则。
  • collation_database:数据库级别的默认排序规则。

参数格式:

排序规则通常由字符集名称和特定的排序后缀组成,如utf8_general_ci。其中,_ci表示大小写不敏感(case-insensitive),_cs表示大小写敏感(case-sensitive),_bin表示二进制排序。

http://www.cndba.cn/cndba/dave/article/131536
http://www.cndba.cn/cndba/dave/article/131536

常用配置值说明:

  • utf8_general_ci:基于UTF-8字符集,大小写不敏感的通用排序规则。
  • utf8_bin:基于UTF-8字符集的二进制排序规则,区分大小写。
  • latin1_swedish_ci:基于latin1字符集,瑞典语大小写不敏感的排序规则。

设置字符集和排序规则

你可以在MySQL配置文件(如my.cnfmy.ini)中设置这些参数,也可以在创建数据库或表时指定。此外,你还可以使用SET语句在运行时动态更改某些参数的值。http://www.cndba.cn/cndba/dave/article/131536http://www.cndba.cn/cndba/dave/article/131536

例如,在创建表时指定字符集和排序规则:

CREATE TABLE my_table (
  id INT,
  name VARCHAR(50)
) CHARACTER SET utf8 COLLATE utf8_general_ci;

这将创建一个使用UTF-8字符集和通用大小写不敏感排序规则的表。

注意事项

  • 在选择字符集和排序规则时,应确保它们与你的应用程序和数据的需求相匹配。
  • 修改字符集或排序规则可能会影响已存储的数据,因此在更改这些设置之前,最好备份你的数据库。
  • 在多语言环境中,建议使用支持多种字符的字符集(如UTF-8),并选择合适的排序规则以确保正确的排序和比较。
mysql> SHOW CHARACTER SET;
+----------+---------------------------------+---------------------+--------+
| Charset  | Description                     | Default collation   | Maxlen |
+----------+---------------------------------+---------------------+--------+
| big5     | Big5 Traditional Chinese        | big5_chinese_ci     |      2 |
| dec8     | DEC West European               | dec8_swedish_ci     |      1 |
| cp850    | DOS West European               | cp850_general_ci    |      1 |
| hp8      | HP West European                | hp8_english_ci      |      1 |
| koi8r    | KOI8-R Relcom Russian           | koi8r_general_ci    |      1 |
| latin1   | cp1252 West European            | latin1_swedish_ci   |      1 |
| latin2   | ISO 8859-2 Central European     | latin2_general_ci   |      1 |
| swe7     | 7bit Swedish                    | swe7_swedish_ci     |      1 |
| ascii    | US ASCII                        | ascii_general_ci    |      1 |
| ujis     | EUC-JP Japanese                 | ujis_japanese_ci    |      3 |
| sjis     | Shift-JIS Japanese              | sjis_japanese_ci    |      2 |
| hebrew   | ISO 8859-8 Hebrew               | hebrew_general_ci   |      1 |
| tis620   | TIS620 Thai                     | tis620_thai_ci      |      1 |
| euckr    | EUC-KR Korean                   | euckr_korean_ci     |      2 |
| koi8u    | KOI8-U Ukrainian                | koi8u_general_ci    |      1 |
| gb2312   | GB2312 Simplified Chinese       | gb2312_chinese_ci   |      2 |
| greek    | ISO 8859-7 Greek                | greek_general_ci    |      1 |
| cp1250   | Windows Central European        | cp1250_general_ci   |      1 |
| gbk      | GBK Simplified Chinese          | gbk_chinese_ci      |      2 |
| latin5   | ISO 8859-9 Turkish              | latin5_turkish_ci   |      1 |
| armscii8 | ARMSCII-8 Armenian              | armscii8_general_ci |      1 |
| utf8     | UTF-8 Unicode                   | utf8_general_ci     |      3 |
| ucs2     | UCS-2 Unicode                   | ucs2_general_ci     |      2 |
| cp866    | DOS Russian                     | cp866_general_ci    |      1 |
| keybcs2  | DOS Kamenicky Czech-Slovak      | keybcs2_general_ci  |      1 |
| macce    | Mac Central European            | macce_general_ci    |      1 |
| macroman | Mac West European               | macroman_general_ci |      1 |
| cp852    | DOS Central European            | cp852_general_ci    |      1 |
| latin7   | ISO 8859-13 Baltic              | latin7_general_ci   |      1 |
| utf8mb4  | UTF-8 Unicode                   | utf8mb4_general_ci  |      4 |
| cp1251   | Windows Cyrillic                | cp1251_general_ci   |      1 |
| utf16    | UTF-16 Unicode                  | utf16_general_ci    |      4 |
| utf16le  | UTF-16LE Unicode                | utf16le_general_ci  |      4 |
| cp1256   | Windows Arabic                  | cp1256_general_ci   |      1 |
| cp1257   | Windows Baltic                  | cp1257_general_ci   |      1 |
| utf32    | UTF-32 Unicode                  | utf32_general_ci    |      4 |
| binary   | Binary pseudo charset           | binary              |      1 |
| geostd8  | GEOSTD8 Georgian                | geostd8_general_ci  |      1 |
| cp932    | SJIS for Windows Japanese       | cp932_japanese_ci   |      2 |
| eucjpms  | UJIS for Windows Japanese       | eucjpms_japanese_ci |      3 |
| gb18030  | China National Standard GB18030 | gb18030_chinese_ci  |      4 |
+----------+---------------------------------+---------------------+--------+
41 rows in set (0.00 sec)

mysql> 
mysql> show variables like '%coll%';
+----------------------+--------------------+
| Variable_name        | Value              |
+----------------------+--------------------+
| collation_connection | utf8_general_ci    |
| collation_database   | utf8mb4_general_ci |
| collation_server     | utf8mb4_general_ci |
+----------------------+--------------------+
3 rows in set (0.01 sec)
用户评论
* 以下用户言论只代表其个人观点,不代表CNDBA社区的观点或立场
dave

dave

关注

人的一生应该是这样度过的:当他回首往事的时候,他不会因为虚度年华而悔恨,也不会因为碌碌无为而羞耻;这样,在临死的时候,他就能够说:“我的整个生命和全部精力,都已经献给世界上最壮丽的事业....."

  • 2261
    原创
  • 3
    翻译
  • 578
    转载
  • 191
    评论
  • 访问:8017534次
  • 积分:4346
  • 等级:核心会员
  • 排名:第1名
精华文章
    最新问题
    查看更多+
    热门文章
      热门用户
      推荐用户
        Copyright © 2016 All Rights Reserved. Powered by CNDBA · 皖ICP备2022006297号-1·

        QQ交流群

        注册联系QQ