每个数据库都有一个数据库字符集和一个数据库排序规则。CREATE DATABASE
andALTER DATABASE
语句具有用于指定数据库字符集和排序规则的可选子句
:
CREATE DATABASE db_name
[[DEFAULT] CHARACTER SET charset_name]
[[DEFAULT] COLLATE collation_name]
ALTER DATABASE db_name
[[DEFAULT] CHARACTER SET charset_name]
[[DEFAULT] COLLATE collation_name]
SCHEMA
可以使用
关键字代替DATABASE
.
CHARACTER SET
and
COLLATE
子句使得在同一个 MySQL 服务器上创建具有不同字符集和排序规则的数据库成为可能
。
数据库选项存储在数据字典中,可以通过检查
INFORMATION_SCHEMA.SCHEMATA
表来检查。
例子:
CREATE DATABASE db_name CHARACTER SET latin1 COLLATE latin1_swedish_ci;
MySQL 通过以下方式选择数据库字符集和数据库排序规则:
如果同时指定了和 ,则使用字符集 和排序规则 。
CHARACTER SET
charset_name
COLLATE
collation_name
charset_name
collation_name
如果没有指定,则使用字符集 及其默认排序规则。要查看每个字符集的默认排序规则,请使用语句或查询 表。
CHARACTER SET
charset_name
COLLATE
charset_name
SHOW CHARACTER SET
INFORMATION_SCHEMA
CHARACTER_SETS
如果没有指定,则使用关联的字符集 和排序规则 。
COLLATE
collation_name
CHARACTER SET
collation_name
collation_name
否则(既未指定
CHARACTER SET
也未COLLATE
指定),将使用服务器字符集和服务器排序规则。
默认数据库的字符集和排序规则可以根据
character_set_database
和
collation_database
系统变量的值确定。每当默认数据库更改时,服务器都会设置这些变量。如果没有默认数据库,则变量与相应的服务器级系统变量具有相同的值,character_set_server
并且collation_server
.
要查看给定数据库的默认字符集和排序规则,请使用以下语句:
USE db_name;
SELECT @@character_set_database, @@collation_database;
或者,要在不更改默认数据库的情况下显示值:
SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME
FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = 'db_name';
数据库字符集和排序规则影响服务器操作的这些方面:
对于
CREATE TABLE
语句,如果未指定表字符集和排序规则,则数据库字符集和排序规则用作表定义的默认值。要覆盖它,请提供显式CHARACTER SET
和COLLATE
表格选项。对于
LOAD DATA
不包含CHARACTER SET
子句的语句,服务器使用character_set_database
系统变量指示的字符集来解释文件中的信息。要覆盖它,请提供一个明确的CHARACTER SET
条款。对于存储例程(过程和函数),在例程创建时有效的数据库字符集和排序规则用作字符数据参数的字符集和排序规则,其声明不包含
CHARACTER SET
或COLLATE
属性。要覆盖它,请CHARACTER SET
明确COLLATE
提供。