• 首页
  • css3教程
  • html5教程
  • jQuery手册
  • vue手册
  • php手册
  • MySQL手册
  • apache手册
  • redis手册
  • 数据库字符集和校验规则

    每个数据库都有一个数据库字符集和一个数据库校验规则。该CREATE DATABASEALTER 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 SETand COLLATE子句可以在同一MySQL服务器上创建具有不同字符集和校验规则的数据库。

    数据库选项存储在数据字典中,可以通过检查INFORMATION_SCHEMA.SCHEMATA表进行检查。

    例:

    CREATE DATABASE db_name CHARACTER SET latin1 COLLATE latin1_swedish_ci;
    

    MySQL通过以下方式选择数据库字符集和数据库校验规则:

    • 如果同时和指定,字符集和校验规则使用。CHARACTER SET charset_nameCOLLATE collation_namecharset_namecollation_name
    • 如果未指定,则使用字符集及其默认校验规则。要参见每个字符集的默认校验规则,请使用语句或查询表。CHARACTER SET charset_nameCOLLATEcharset_nameSHOW CHARACTER SETINFORMATION_SCHEMACHARACTER_SETS
    • 如果不指定,则使用与和归类相关的字符集。COLLATE collation_nameCHARACTER SETcollation_namecollation_name
    • 否则(既未指定,也CHARACTER SETCOLLATE指定),将使用服务器字符集和服务器校验规则。

    缺省数据库的字符集和校验规则可以从character_set_databasecollation_database系统变量的值确定。每当默认数据库更改时,服务器都会设置这些变量。如果没有默认数据库,变量具有相同的值与相应的服务器级的系统变量,character_set_servercollation_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 SETCOLLATE表选项。
    • 对于LOAD DATA不包含CHARACTER SET子句的语句,服务器使用character_set_database系统变量指示的字符集来解释文件中的信息。要覆盖此内容,请提供一个显式CHARACTER SET子句。
    • 对于存储的例程(过程和函数),将在例程创建时生效的数据库字符集和校验规则用作声明不包含CHARACTER SETCOLLATE属性的字符数据参数的字符集和校验规则。要覆盖此内容,请提供CHARACTER SETCOLLATE明确提供。