Warning

CREATE TABLESPACE

CREATE TABLESPACE —定义一个新的表空间

Synopsis

CREATE TABLESPACE tablespace_name
    [ OWNER { new_owner | CURRENT_USER | SESSION_USER } ]
    LOCATION 'directory'
    [ WITH ( tablespace_option = value [, ... ] ) ]

Description

CREATE TABLESPACE注册一个新的群集范围的表空间。表空间名称必须与数据库集群中任何现有表空间的名称不同。

表空间允许超级用户在文件系统上定义备用位置,该位置上可以包含数据库对象(例如表和索引)的数据文件。

具有适当特权的用户可以将* tablespace_name *传递给CREATE DATABASECREATE TABLECREATE INDEXADD CONSTRAINT,以将这些对象的数据文件存储在指定的表空间中。

Warning

表空间不能独立于定义表空间的集群使用。参见Section 22.6

Parameters

  • tablespace_name

    • 要创建的表空间的名称。该名称不能以pg_开头,因为此类名称是为系统表空间保留的。
  • user_name

    • 拥有表空间的用户名。如果省略,则默认为执行命令的用户。只有超级用户可以创建表空间,但是他们可以将表空间的所有权分配给非超级用户。
  • directory

    • 将用于表空间的目录。该目录应该为空,并且必须由 PostgreSQL 系统用户拥有。该目录必须由绝对路径名指定。
  • tablespace_option

    • 要设置或重置的表空间参数。当前,唯一可用的参数是seq_page_costrandom_page_costeffective_io_concurrency。根据特定名称的配置参数确定的值,为特定表空间设置这两个值都将覆盖计划者通常对从该表空间中的表中读取页面的开销的估计(请参见seq_page_costrandom_page_costeffective_io_concurrency)。如果一个表空间位于比 I/O 子系统的其余部分更快或更慢的磁盘上,这可能很有用。

Notes

表空间仅在支持符号链接的系统上受支持。

CREATE TABLESPACE无法在事务块内执行。

Examples

/data/dbs处创建一个表空间dbspace

CREATE TABLESPACE dbspace LOCATION '/data/dbs';

在用户genevieve拥有的/data/indexes处创建表空间indexspace

CREATE TABLESPACE indexspace OWNER genevieve LOCATION '/data/indexes';

Compatibility

CREATE TABLESPACE是 PostgreSQL 扩展。

See Also

CREATE DATABASE, CREATE TABLE, CREATE INDEX, DROP TABLESPACE, ALTER TABLESPACE