跳到主要内容

表级字符集和字符序

每张表都有默认字符集和默认字符序。

指定表的字符集和字符序

CREATE TABLEALTER TABLE 语句具有用于指定表的字符集和字符序,语法如下:

CREATE TABLE table_name (column_list)
[[DEFAULT] CHARACTER SET [=] charset_name]
[COLLATE [=] collation_name]

ALTER TABLE table_name
[DEFAULT] CHARACTER SET [=] charset_name
[COLLATE [=] collation_name]

修改表中已有数据的字符集和字符序的语法如下:

ALTER TABLE tbl_name CONVERT TO CHARACTER SET charset_name COLLATE col_name;

示例如下:

CREATE TABLE test_collation (c1 INT, c2 VARCHAR(32), c3 VARCHAR(32), PRIMARY KEY (c1),UNIQUE KEY idx_test_collation_c2(c2));
Query OK, 0 rows affected (0.107 sec)

//修改表的字符集和字符序
ALTER TABLE test_collation CHARACTER SET = utf8mb4 COLLATE = utf8mb4_bin;
Query OK, 0 rows affected (0.109 sec)

// 修改表中已有数据的字符集和字符序,并修改对应的设置
ALTER TABLE test_collation CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_bin;
Query OK, 0 rows affected (0.025 sec)

选择表的字符集和字符序

seekdb 通过以下方式选择表的字符集和字符序:

  • 如果同时指定了 CHARACTER SET charset_nameCOLLATE collation_name,则使用字符集 charset_name 和字符序 collation_name

  • 如果指定了 CHARACTER SET charset_name 但未指定 COLLATE,则使用字符集 charset_name 及其默认字符序。要查看每个字符集的默认字符序,请使用 SHOW CHARACTER SET 语句。

  • 如果指定了 COLLATE collation_name 但未指定 CHARACTER SET,则使用与 collation_name 关联的字符集和指定的字符序。

  • 如果既不指定 CHARACTER SET 也不指定 COLLATE,则使用数据库的字符集和字符序。

如果在各个列定义中未指定列字符集和字符序,则表的字符集和字符序将用作列定义的默认值。