方案从逻辑上组织一个数据库中的对象和数据。方案允许用户在同一个数据库中拥有多于一个对象(例如表)具有相同的名称而不发生冲突,只要把它们放在不同的方案中就好。
每个数据库都一个名为public的默认方案。如果用户没有创建任何方案,对象会被创建在这个public方案中。所有的数据库角色(用户)都在public方案中拥有 CREATE和USAGE特权。在用户创建一个方案时,用户应该为允许访问该方案的用户授予特权。
可以使用CREATE SCHEMA命令来创建一个新的方案。例如:
=> CREATE SCHEMA myschema;
要在一个方案中创建或者访问对象,需要写一个由方案名和表名构成的限定名,两者之间用点号隔开。例如:
myschema.table
用户可以创建一个由他人拥有的方案,例如用来把用户的活动限定在定义良好的名字空间内。语法是:
=> CREATE SCHEMA schemaname AUTHORIZATION username;
要在数据库中指定一个对象的位置,请使用方案限定的名称。例如:
=> SELECT * FROM myschema.mytable;
用户可以设置search_path配置参数来指定在其中搜索对象的可用方案的顺序。在该搜索路径中第一个列出的方案会成为所谓的默认方案。如果没有指定方案,对象会被创建在默认方案中。
search_path配置参数设置方案搜索顺序。ALTER DATABASE命令可以设置搜索路径。例如:
=> ALTER DATABASE mydatabase SET search_path TO myschema,
public, pg_catalog;
用户也可以使用ALTER ROLE命令为特定的角色(用户)设置search_path。例如:
=> ALTER ROLE sally SET search_path TO myschema, public,
pg_catalog;
使用current_schema()函数可以查看当前的方案。例如:
=> SELECT current_schema();
使用SHOW命令可以查看当前的搜索路径。例如:
=> SHOW search_path;
使用DROP SCHEMA命令可以删除一个方案。例如:
=> DROP SCHEMA myschema;
默认情况下,在能够删除一个方案前,它必须为空。要删除一个方案连同其中的所有对象(表、数据、函数等等),可以使用:
=> DROP SCHEMA myschema CASCADE;
下列系统级方案存在于每一个数据库中:
评论区(0)