# 创建表空间

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

# 概要

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

# 描述

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

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

具有适当权限的用户可以通过*表空间名称*到创建数据库,创建表,创建索引要么添加约束将这些对象的数据文件存储在指定的表空间中。

# 警告

表空间不能独立于定义它的集群使用;看第 23.6 节.

# 参数

表空间名称

要创建的表空间的名称。名字不能以pg_,因为这样的名称是为系统表空间保留的。

用户名

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

目录

将用于表空间的目录。该目录必须存在 (创建表空间不会创建它),应该是空的,并且必须由 PostgreSQL 系统用户拥有。目录必须由绝对路径名指定。

表空间选项

要设置或重置的表空间参数。目前,唯一可用的参数是seq_page_cost,random_page_cost,effective_io_concurrency维护_io_并发.为特定表空间设置这些值将覆盖规划器通常估计的从该表空间中的表读取页面的成本,以及执行器的预取行为,由同名的配置参数建立(参见序列_页_成本,随机的_页_成本,有效的_io_并发,维护_io_并发)。如果一个表空间位于比 I/O 子系统的其余部分更快或更慢的磁盘上,这可能很有用。

# 笔记

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

创建表空间不能在事务块内执行。

# 例子

创建表空间数据库空间在文件系统位置/数据/数据库,首先使用操作系统工具创建目录并设置正确的所有权:

mkdir /data/dbs
chown postgres:postgres /data/dbs

然后在 PostgreSQL 中发出表空间创建命令:

CREATE TABLESPACE dbspace LOCATION '/data/dbs';

要创建由不同数据库用户拥有的表空间,请使用如下命令:

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

# 兼容性

创建表空间是一个 PostgreSQL 扩展。

# 也可以看看

创建数据库, 创建表, 创建索引, 删除表空间, 改变表空间