更新时间:2025-09-12 GMT+08:00
分享

CREATE SCHEMA

功能描述

创建模式。DATABASE与SCHEMA同义。

访问命名对象时可以使用模式名作为前缀进行访问,如果无模式名前缀,则访问当前模式下的命名对象。创建命名对象时也可用模式名作为前缀修饰。

另外,CREATE SCHEMA可以包括在新模式中创建对象的子命令,这些子命令和那些在创建完模式后发出的命令没有任何区别。如果使用了AUTHORIZATION子句,则所有创建的对象都将被该用户所拥有。

注意事项

  • 只要用户对当前数据库有CREATE权限,就可以创建模式。
  • 系统管理员在普通用户同名schema下创建的对象,所有者为schema的同名用户(非系统管理员)。

语法格式

CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] schema_name
    [[create_option] [,...]]
create_option: [DEFAULT] {
    CHARACTER SET [=] default_charset
  | CHAR SET [=] default_charset
  | CHARSET [=] default_charset
  | COLLATE [=] default_collation
}

参数说明

  • schema_name

    模式名称。

    • 模式名不能和当前数据库里其他的模式重名。
    • 模式名不能和当前数据库的初始用户重名。
    • 模式的名称不可以“pg_”开头。
    • 模式的名称不可以“gs_role_”开头。

    取值范围:字符串,要符合标识符说明

如果当前搜索路径上的模式中存在同名对象时,需要明确指定引用对象所在的模式。可以通过命令SHOW SEARCH_PATH来查看当前搜索路径上的模式。

  • COLLATE [=] collation_name

    可选。指定新数据库使用的字符集。例如,通过collate = 'zh_CN.gbk'设定该参数。

    该参数的使用会影响到对字符串的排序顺序(如使用ORDER BY执行,以及在文本列上使用索引的顺序)。默认是使用模板数据库的字符集。

    取值范围:参考库级字符集和字符序

  • {CHAR SET | CHARSET | CHARACTER SET} [=] charset_name

    可选。指定新数据库使用的字符分类。例如,通过CHARSET = 'zh_CN.gbk'设定该参数。该参数的使用会影响到字符的分类,如大写、小写和数字。默认是使用模板数据库的字符分类。

    取值范围:参考库级字符集和字符序

示例

--创建并切换至测试数据库。
m_db=# CREATE SCHEMA test1;
m_db=# USE test1;
--创建表a。
m_db=# CREATE TABLE a(id int);
m_db=# DROP TABLE a;
--删除SCHEMA test1。
m_db=# USE public;
m_db=# DROP SCHEMA test1;

相关链接

ALTER SCHEMADROP SCHEMA

相关文档