CREATE SCHEMA schemaname [ AUTHORIZATION username ] [ schema_element [ ... ] ] CREATE SCHEMA AUTHORIZATION username [ schema_element [ ... ] ]
CREATE SCHEMA 在当前数据库里输入一个新模式。该模式名将在当前数据库里现存的所有模式名中唯一。
模式实际上是一个名字空间:它包含命名对象(表、数据类型、函数、操作符)这些名字可以和其它模式里存在的其它对象重名。命名对象要么是通过用模式名作为前缀"修饰"进行访问,要么是通过设置一个搜索路径包含所需要的模式。一条带着无修饰对象名的 CREATE 命令都是在当前模式中创建的(在搜索路径最前面的模式;可以用 current_schema
函数来判断)。
另外,CREATE SCHEMA 可以包括在新模式中创建对象的子命令。这些子命令和那些在创建完模式后发出的命令没有任何区别,只不过是如果使用了 AUTHORIZATION 子句,那么所有创建的对象都将被该用户拥有。
要创建的模式名字。如果省略,则使用用户名作为模式名。这个名字不能以 pg_ 开头,因为这样的名字保留给系统模式使用。
将拥有该模式的用户名。如果省略,缺省为执行该命令的用户名。只有超级用户才能创建不属于自己的模式。
一个 SQL 语句,定义一个要在模式里创建的对象。目前,只有 CREATE TABLE, CREATE VIEW, CREATE INDEX, CREATE SEQUENCE, CREATE TRIGGER, GRANT 是可以接受的子句。其它类型的对象可以在创建完模式之后的独立命令里创建。
创建一个模式:
CREATE SCHEMA myschema;
为用户 joe 创建模式,模式名也叫 joe :
CREATE SCHEMA AUTHORIZATION joe;
创建一个模式并且在里面创建一个表:
CREATE SCHEMA hollywood CREATE TABLE films (title text, release date, awards text[]) CREATE VIEW winners AS SELECT title, release FROM films WHERE awards IS NOT NULL;
请注意上面独立的子命令不是由分号结尾的。
下面的命令是实现同样结果的等效语句:
CREATE SCHEMA hollywood; CREATE TABLE hollywood.films (title text, release date, awards text[]); CREATE VIEW hollywood.winners AS SELECT title, release FROM hollywood.films WHERE awards IS NOT NULL;