CREATE TABLESPACE
CREATE TABLESPACE - 定义一个新的表空间
语法格式
CREATE TABLESPACE tablespace_name
[ OWNER { new_owner | CURRENT_USER | SESSION_USER } ]
LOCATION 'directory'
[ WITH ( tablespace_option = value [, ... ] ) ]
说明
CREATE TABLESPACE 注册一个新的 集群范围的表空间。表空间名称必须与数据库集群中任何现有表空间的名称不同。
表空间允许超级用户在文件系统上定义备用位置,其中包含数据库对象(例如表和索引)的数据文件可以驻留在该位置。
具有适当权限的用户可以将 tablespace_name 传递给 CREATE DATABASE ,CREATE TABLE , CREATE INDEX 或 ADD CONSTRAINT,以使这些对象的数据文件存储在指定的表空间中。
参数说明
tablespace_name
The name of a tablespace to be created. The name cannot begin with pg_, as such names are reserved for system tablespaces.
user_name
将拥有该表空间的用户名。如果省略,默认为执行该命令的用户。只有 超级用户能创建表空间,但是它们能把表空间的拥有权赋予给非超级 用户。
directory
要被用于表空间的目录。该目录应该为空并且必须由 Vastbase E100系统用户拥有。该目录必须用一个绝对 路径指定。
tablespace_option
要设置或者重置的表空间参数。当前,唯一可用的参数是 seq_page_cost、random_page_cost 以及effective_io_concurrency。 为一个特定表空间设定其中一个值将覆盖规划器对该表空间中表页读取的 常规代价估计,常规代价估计是由同名的配置参数所建立(见 seq_page_cost、 random_page_cost、 effective_io_concurrency)。如果一个表空间位于一个 比其他 I/O 子系统更慢或者更快的磁盘上,这些参数就能发挥作用。
注意事项
表空间仅在支持符号链接的系统上受支持。
CREATE TABLESPACE 无法在事务块内执行。
示例
在 /data/dbs 创建一个表空间 dbspace :
CREATE TABLESPACE dbspace LOCATION '/data/dbs';
在用户 genevieve 拥有的 /data/indexes 创建一个表空间 indexspace :
CREATE TABLESPACE indexspace OWNER genevieve LOCATION '/data/indexes';