ALTER INDEX — 更改一个索引的定义
ALTER INDEX [ IF EXISTS ]name
RENAME TOnew_name
ALTER INDEX [ IF EXISTS ]name
SET TABLESPACEtablespace_name
ALTER INDEXname
DEPENDS ON EXTENSIONextension_name
ALTER INDEX [ IF EXISTS ]name
SET (storage_parameter
=value
[, ... ] ) ALTER INDEX [ IF EXISTS ]name
RESET (storage_parameter
[, ... ] ) ALTER INDEX ALL IN TABLESPACEname
[ OWNED BYrole_name
[, ... ] ] SET TABLESPACEnew_tablespace
[ NOWAIT ]
ALTER INDEX
更改一个现有索引的定义。
它有几种形式:
RENAME
RENAME
形式更改该索引的名称。这对已存储的数据没有
影响。
SET TABLESPACE
这种形式更改该索引的表空间为指定的表空间,并且把与该索引相关联的数据文件
移动到新的表空间中。要更改一个索引的表空间,你必须拥有该索引并且具有新表
空间上的CREATE
特权。可以使用
ALL IN TABLESPACE
形式把当前数据库中在一个表空间内的
所有索引全部移动到另一个表空间中,这将会锁定所有要被移动的索引然后挨个移
动它们。这种形式也支持OWNED BY
,即只移动属于指定角色
的索引。如果指定了NOWAIT
选项,那么当该命令无法立刻获
得所有锁时将会失败。注意这个命令不会移动系统目录,如果想要移动系统目录,
应使用ALTER DATABASE
或者显式的
ALTER INDEX
调用。另见
CREATE TABLESPACE。
DEPENDS ON EXTENSION
这种形式把该索引标记为依赖于扩展,这样如果该扩展被删除,该索引也将被 自动删除。
SET ( storage_parameter
= value
[, ... ] )
这种形式为该索引更改一个或者多个索引方法相关的存储参数。可用的参数详见 CREATE INDEX。注意这个命令不会立刻修改索引内容, 根据参数你可能需要用REINDEX重建索引来得到想要的 效果。
RESET ( storage_parameter
[, ... ] )
这种形式把一个或者多个索引方法相关的存储参数重置为其默认值。正如
SET
一样,可能需要一次REINDEX
来完全更新
该索引。
IF EXISTS
如果该索引不存在不要抛出错误。这种情况下将发出一个提示。
name
要更改的一个现有索引的名称(可能被模式限定)。
new_name
该索引的新名称。
tablespace_name
该索引将被移动到的表空间。
extension_name
该索引所依赖的扩展的名称。
storage_parameter
一个索引方法相关的存储参数的名称。
value
一个索引方法相关的存储参数的新值。根据该参数,这可能是一个数字或者一个 词。
也可以用ALTER TABLE来做这些操作。实际上,
ALTER INDEX
只是ALTER TABLE
应用在索引
上的形式的别名而已。
以前有一种ALTER INDEX OWNER
变体,但现在已被忽略(会出现
一个警告)。一个索引的拥有者不能与其基表的拥有者不同。更改基表的拥有者
会自动地更改索引的拥有者。
不允许更改系统目录索引的任何部分。
要重命名一个现有索引:
ALTER INDEX distributors RENAME TO suppliers;
把一个索引移动到一个不同的表空间:
ALTER INDEX distributors SET TABLESPACE fasttablespace;
更改一个索引的填充因子(假设该索引方法支持填充因子):
ALTER INDEX distributors SET (fillfactor = 75); REINDEX INDEX distributors;
ALTER INDEX
是一种
PostgreSQL扩展。