On this page
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 DATABASE
,CREATE TABLE
,CREATE INDEX
或ADD CONSTRAINT
,以将这些对象的数据文件存储在指定的表空间中。
Warning
表空间不能独立于定义表空间的集群使用。参见Section 22.6。
Parameters
tablespace_name
- 要创建的表空间的名称。该名称不能以
pg_
开头,因为此类名称是为系统表空间保留的。
- 要创建的表空间的名称。该名称不能以
user_name
- 拥有表空间的用户名。如果省略,则默认为执行命令的用户。只有超级用户可以创建表空间,但是他们可以将表空间的所有权分配给非超级用户。
directory
- 将用于表空间的目录。该目录应该为空,并且必须由 PostgreSQL 系统用户拥有。该目录必须由绝对路径名指定。
tablespace_option
- 要设置或重置的表空间参数。当前,唯一可用的参数是
seq_page_cost
,random_page_cost
和effective_io_concurrency
。根据特定名称的配置参数确定的值,为特定表空间设置这两个值都将覆盖计划者通常对从该表空间中的表中读取页面的开销的估计(请参见seq_page_cost,random_page_cost,effective_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