ALTER COLLATION — 更改一个排序规则的定义
ALTER COLLATIONname
REFRESH VERSION ALTER COLLATIONname
RENAME TOnew_name
ALTER COLLATIONname
OWNER TO {new_owner
| CURRENT_USER | SESSION_USER } ALTER COLLATIONname
SET SCHEMAnew_schema
ALTER COLLATION
更改一个排序规则的定义。
你必须拥有要对其使用ALTER COLLATION
的排序规则。要更改拥有者,你必须是新的拥有角色的直接或者间接成员,并且该角色必须在排序规则的模式上具有CREATE
特权(这些限制强制要求拥有者不能通过丢弃并重建该排序规则来做任何你不能做的事情。不过,一个超级用户可以更改任何排序规则的所有权)。
name
一个现有排序规则的名称(可以是模式限定的)。
new_name
排序规则的新名称。
new_owner
排序规则的新拥有者。
new_schema
排序规则的新模式。
REFRESH VERSION
更新排序规则的版本。见下文的说明。
在使用由ICU库提供的排序规则时,排序器的ICU版本会在创建排序规则对象时被记录在系统目录中。在使用排序规则时,会根据记录的版本检查当前的版本,出现失配时会发出警告,例如:
WARNING: collation "xx-x-icu" has version mismatch DETAIL: The collation in the database was created using version 1.2.3.4, but the operating system provides version 2.3.4.5. HINT: Rebuild all objects affected by this collation and run ALTER COLLATION pg_catalog."xx-x-icu" REFRESH VERSION, or build PostgreSQL with the right library version.
排序规则定义中的变化可能会导致损坏索引以及其他问题,因为数据库系统依赖于将对象按照特定的排序顺序存放。通常来说这种问题应该被避免,但是它仍然可能发生在正常的情况中,例如在使用pg_upgrade
升级到链接到更新版本的ICU的服务器二进制文件时。如果发生这种问题,所有依赖于排序规则的对象都应该被重建,例如通过使用REINDEX
。当重建完成后,排序规则的版本可以使用命令ALTER COLLATION ... REFRESH
VERSION
刷新。这个命令将更新系统目录以记录当前的排序器版本并且让警告不再发生。注意这个命令并不会检查所有受影响的对象是否已经被正确地重建。
下面的查询可以用来标识出当前数据库中所有需要被刷新的排序规则以及依赖于它们的对象:
SELECT pg_describe_object(refclassid, refobjid, refobjsubid) AS "Collation", pg_describe_object(classid, objid, objsubid) AS "Object" FROM pg_depend d JOIN pg_collation c ON refclassid = 'pg_collation'::regclass AND refobjid = c.oid WHERE c.collversion <> pg_collation_actual_version(c.oid) ORDER BY 1, 2;
要把排序规则de_DE
重命名为german
:
ALTER COLLATION "de_DE" RENAME TO german;
要把排序规则en_US
的拥有者改成joe
:
ALTER COLLATION "en_US" OWNER TO joe;
在 SQL 标准中没有ALTER COLLATION
语句。