ALTER COLLATION — 更改排序规则的定义
ALTER COLLATIONnameREFRESH VERSION ALTER COLLATIONnameRENAME TOnew_nameALTER COLLATIONnameOWNER TO {new_owner| CURRENT_ROLE | CURRENT_USER | SESSION_USER } ALTER COLLATIONnameSET SCHEMAnew_schema
ALTER COLLATION更改排序规则的定义。
要使用ALTER COLLATION,你必须拥有该排序规则。 要更改拥有者,你必须能够对新的拥有角色执行SET ROLE, 并且该角色必须在该排序规则所在模式上具有CREATE权限。 (这些限制确保更改拥有者不会做出任何你无法通过删除并重新创建该排序 规则来完成的事情。不过,超级用户无论如何都可以更改任何排序规则的所 有权。)
创建排序规则对象时,该排序规则的提供者特定版本会记录在系统目录中。 使用该排序规则时,会将当前版本与记录的版本进行比较;如果二者不匹 配,就会发出警告,例如:
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刷新排序规则 版本。这样会更新系统目录,使其记录当前的排序规则版本,并让该警告消 失。请注意,这实际上并不会检查所有受影响对象是否都已被正确重建。
当使用libc提供的排序规则时,在使用 GNU C 库 (大多数 Linux 系统)、FreeBSD 和 Windows 的系统上会记录版本信息。 当使用 ICU 提供的排序规则时,版本信息由 ICU 库提供,并且在所有平台 上都可用。
当使用 GNU C 库提供的排序规则时,C 库版本会被用作排序规则版本的代 理。许多 Linux 发行版只有在升级 C 库时才会更改排序规则定义,但这种 方法并不完美,因为维护人员也可以自由地将较新的排序规则定义回移植到 较旧的 C 库版本中。
在 Windows 上使用排序规则时,版本信息仅适用于用 BCP 47 语言标签定 义的排序规则,例如en-US。
对于数据库默认排序规则,有一个对应的命令 ALTER DATABASE ... REFRESH COLLATION 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语句。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。