ALTER TABLESPACE — 更改表空间定义
ALTER TABLESPACEnameRENAME TOnew_nameALTER TABLESPACEnameOWNER TO {new_owner| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER TABLESPACEnameSET (tablespace_option=value[, ... ] ) ALTER TABLESPACEnameRESET (tablespace_option[, ... ] )
ALTER TABLESPACE 可用于更改表空间定义。
您必须拥有该表空间才能更改其定义。要更改所有者,您还必须能够 SET ROLE 到新的所有者角色。(请注意,超级用户自动拥有这些权限。)
name现有表空间的名称。
new_name表空间的新名称。新名称不能以 pg_ 开头,因为此类名称保留给系统表空间。
new_owner表空间的新所有者。
tablespace_option要设置或重置的表空间参数。目前,唯一可用的参数是 seq_page_cost、random_page_cost、effective_io_concurrency 和 maintenance_io_concurrency。为特定表空间设置这些值将覆盖规划器对从该表空间中的表读取页的成本的常规估计,以及并发 I/O 的数量,这些通常由同名配置参数建立(请参阅 seq_page_cost、random_page_cost、effective_io_concurrency、maintenance_io_concurrency)。如果某个表空间位于比其他 I/O 子系统更快的磁盘上,则这可能很有用。
将表空间 index_space 重命名为 fast_raid
ALTER TABLESPACE index_space RENAME TO fast_raid;
更改表空间 index_space 的所有者
ALTER TABLESPACE index_space OWNER TO mary;
SQL 标准中没有 ALTER TABLESPACE 语句。