CREATE SCHEMA
功能描述
创建模式。
访问命名对象时可以使用模式名作为前缀进行访问,如果无模式名前缀,则访问当前模式下的命名对象。创建命名对象时也可用模式名作为前缀修饰。
另外,CREATE SCHEMA可以包括在新模式中创建对象的子命令,这些子命令和那些在创建完模式后发出的命令没有任何区别。如果使用了AUTHORIZATION子句,则所有创建的对象都将被该用户所拥有。
注意事项
- 一个数据库可以包含一个或多个已命名的Schema,Schema又包含表及其他数据库对象,包括数据类型、函数、操作符等。同一对象名可以在不同的Schema中使用而不会引起冲突。例如,Schema1和Schema2都可以包含一个名为mytable的表。
- 和数据库不同,Schema不是严格分离的。用户根据其对Schema的权限,可以访问所连接数据库的Schema中的对象。进行Schema权限管理首先需要对数据库的权限控制进行了解。
- 不能创建以PG_为前缀的Schema名,该类Schema为数据库系统预留的。
- 在当前数据库中创建用户时,系统会在当前数据库中为新用户创建一个同名Schema。
- 只要用户对当前数据库有CREATE权限,就可以创建Schema。
- 系统管理员在普通用户同名Schema下创建的对象,所有者为Schema的同名用户(非系统管理员)。
- 通过未修饰的表名(名字中只含有表名,没有“Schema名”)引用表时,系统会通过search_path(搜索路径)来判断该表是哪个Schema下的表。pg_temp和pg_catalog始终会作为搜索路径顺序中的前两位,无论二者是否出现在search_path中,或者出现在search_path中的任何位置。search_path(搜索路径)是一个Schema名列表,在其中找到的第一个表就是目标表,如果没有找到则报错。某个表即使存在,如果它的Schema不在search_path中,依然会查找失败,在搜索路径中的第一个Schema叫做“当前Schema”。它是搜索时查询的第一个Schema,同时在没有声明Schema名时,新创建的数据库对象会默认存放在该Schema下。
语法格式
- 根据指定的名字创建模式:
1 2
CREATE SCHEMA schema_name [ AUTHORIZATION user_name ] [ WITH PERM SPACE 'space_limit'] [ schema_element [ ... ] ];
- 根据用户名创建模式:
1
CREATE SCHEMA AUTHORIZATION user_name [ WITH PERM SPACE 'space_limit'] [ schema_element [ ... ] ];
参数说明
- schema_name
模式名字。
- 模式名不能和当前数据库里其他的模式重名。
- 模式的名字不可以“pg_”开头。
取值范围:字符串,要符合标识符的命名规范。
- AUTHORIZATION user_name
指定模式的所有者。当不指定schema_name时,把user_name当作模式名,此时user_name只能是角色名。
取值范围:已存在的用户名/角色名。
- WITH PERM SPACE 'space_limit'
指定模式的永久表存储空间上限。当不指定space_limit时,则不限制。
取值范围:字符串格式为正整数+单位,单位当前支持K/M/G/T/P。解析后的数值以K为单位,且范围不能够超过64比特表示的有符号整数,即1KB~9007199254740991KB。
- schema_element
在模式里创建对象的SQL语句。目前仅支持CREATE TABLE、CREATE VIEW、CREATE INDEX、CREATE PARTITION、GRANT子句。
子命令所创建的对象都被AUTHORIZATION子句指定的用户所拥有。
如果当前搜索路径上的模式中存在同名对象时,需要明确指定引用对象所在的模式。可以通过命令SHOW SEARCH_PATH来查看当前搜索路径上的模式。
示例
创建一个角色role1:
1
|
CREATE ROLE role1 IDENTIFIED BY '{Password}'; |
为用户role1创建一个同名schema,子命令创建的表films和winners的拥有者为role1:
1 2 3 4 |
CREATE SCHEMA AUTHORIZATION role1 CREATE TABLE films (title text, release date, awards text[]) CREATE VIEW winners AS SELECT title, release FROM films WHERE awards IS NOT NULL; |