table of contents
- buster 11.9-0+deb10u1
CREATE TABLESPACE(7) | PostgreSQL 11.9 Documentation | CREATE TABLESPACE(7) |
NAME¶
CREATE_TABLESPACE - define a new tablespaceSYNOPSIS¶
CREATE TABLESPACE tablespace_name [ OWNER { new_owner | CURRENT_USER | SESSION_USER } ] LOCATION 'directory' [ WITH ( tablespace_option = value [, ... ] ) ]
DESCRIPTION¶
CREATE TABLESPACE registers a new cluster-wide tablespace. The tablespace name must be distinct from the name of any existing tablespace in the database cluster.A tablespace allows superusers to define an alternative location on the file system where the data files containing database objects (such as tables and indexes) can reside.
A user with appropriate privileges can pass tablespace_name to CREATE DATABASE, CREATE TABLE, CREATE INDEX or ADD CONSTRAINT to have the data files for these objects stored within the specified tablespace.
Warning
A tablespace cannot be used independently of the cluster in which it is defined; see Section 22.6.
PARAMETERS¶
tablespace_nameuser_name
directory
tablespace_option
NOTES¶
Tablespaces are only supported on systems that support symbolic links.CREATE TABLESPACE cannot be executed inside a transaction block.
EXAMPLES¶
Create a tablespace dbspace at /data/dbs:CREATE TABLESPACE dbspace LOCATION '/data/dbs';
Create a tablespace indexspace at /data/indexes owned by user genevieve:
CREATE TABLESPACE indexspace OWNER genevieve LOCATION '/data/indexes';
COMPATIBILITY¶
CREATE TABLESPACE is a PostgreSQL extension.SEE ALSO¶
CREATE DATABASE (CREATE_DATABASE(7)), CREATE TABLE (CREATE_TABLE(7)), CREATE INDEX (CREATE_INDEX(7)), DROP TABLESPACE (DROP_TABLESPACE(7)), ALTER TABLESPACE (ALTER_TABLESPACE(7))2020 | PostgreSQL 11.9 |