# 更改排序规则

更改排序规则-更改排序规则的定义

# 提要

ALTER COLLATION name REFRESH VERSION

ALTER COLLATION name RENAME TO new_name
ALTER COLLATION name OWNER TO { new_owner | CURRENT_ROLE | CURRENT_USER | SESSION_USER }
ALTER COLLATION name SET SCHEMA new_schema

# 描述

更改排序规则更改排序规则的定义。

您必须拥有要使用的排序规则更改排序规则。要更改所有者,您还必须是新所有者角色的直接或间接成员,并且该角色必须具有创造排序规则架构上的权限。(这些限制强制要求更改所有者不会做任何您无法通过删除和重新创建排序规则来做的事情。但是,超级用户无论如何都可以更改任何排序规则的所有权。)

# 参数

名称

现有排序规则的名称(可选架构限定)。

新名字

排序规则的新名称。

新老板

排序规则的新所有者。

新的_模式

排序规则的新模式。

刷新版本

更新排序规则的版本。看见笔记在下面

# 笔记

使用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_升级升级到与新版ICU链接的服务器二进制文件。发生这种情况时,所有依赖于排序规则的对象都应该重新生成,例如,使用重新索引。完成后,可以使用命令刷新排序规则版本更改排序规则。。。刷新版本。这将更新系统目录,以记录当前的collator版本,并使警告消失。请注意,这实际上并不检查是否已正确重建所有受影响的对象。

使用由提供的排序规则时libc,版本信息记录在使用GNU C库(大多数Linux系统)、FreeBSD和Windows的系统上。

# 笔记

使用GNU C库进行排序时,C库的版本用作排序版本的代理。许多Linux发行版仅在升级C库时才更改排序规则定义,但这种方法并不完美,因为维护人员可以自由地将较新的排序规则定义移植到较旧的C库版本。

使用Windows进行排序时,版本信息仅适用于使用BCP 47语言标记定义的排序,例如恩我们.

目前,没有数据库默认排序规则的版本跟踪。

以下查询可用于标识当前数据库中需要刷新的所有排序规则以及依赖它们的对象:

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;

# 例子

重命名排序规则德乌德德国的:

ALTER COLLATION "de_DE" RENAME TO german;

更改排序规则的所有者恩!:

ALTER COLLATION "en_US" OWNER TO joe;

# 兼容性

没有更改排序规则SQL标准中的语句。

# 另见

创建排序规则, 删除排序