受支持版本: 当前版本 (18) / 17 / 16 / 15 / 14
开发版本: devel

CREATE COLLATION

CREATE COLLATION — 定义一种新排序规则

Synopsis

CREATE COLLATION [ IF NOT EXISTS ] name (
    [ LOCALE = locale, ]
    [ LC_COLLATE = lc_collate, ]
    [ LC_CTYPE = lc_ctype, ]
    [ PROVIDER = provider, ]
    [ DETERMINISTIC = boolean, ]
    [ RULES = rules, ]
    [ VERSION = version ]
)
CREATE COLLATION [ IF NOT EXISTS ] name FROM existing_collation

描述

CREATE COLLATION使用指定的操作系统区域设 置,或者通过复制现有排序规则,定义一个新的排序规则。

要创建排序规则,你必须拥有目标模式上的 CREATE权限。

参数

IF NOT EXISTS #

如果同名排序规则已经存在,则不要抛出错误。在这种情况下会发出一条 通知。请注意,不保证现有的排序规则与本应创建出的排序规则有任何相 似之处。

name #

排序规则的名称,可以使用模式限定。若未使用模式限定,则该排序规则 会在当前模式中定义。排序规则名称在该模式内必须唯一。(系统目录中 可以包含针对其他编码的同名排序规则,但如果数据库编码不匹配,则会 忽略它们。)

locale #

该排序规则的区域设置名称。详见Section 23.2.2.3.1Section 23.2.2.3.2

如果providerlibc, 这相当于同时设置LC_COLLATELC_CTYPE。如果指定了 locale,则不能再指定这两个参数中的任何 一个。

如果providerbuiltin, 则必须指定locale,且其值只能是 CC.UTF-8PG_UNICODE_FAST

lc_collate #

如果providerlibc, 则对LC_COLLATE区域类别使用指定的操作系统区域设 置。

lc_ctype #

如果providerlibc, 则对LC_CTYPE区域类别使用指定的操作系统区域设置。

provider #

指定与该排序规则关联的区域设置服务所使用的提供者。可能的值是 builtinicu (如果服务器在构建时启用了 ICU 支持)或libc。 默认值是libc。详见Section 23.1.4

DETERMINISTIC #

指定该排序规则是否应使用确定性比较。默认值为 true。确定性比较认 为,凡不是按字节完全相等的字符串,即使比较在逻辑上认为它们相等, 也应视为不相等。PostgreSQL会使用按字 节比较来打破平局。非确定性比较可以使排序规则例如不区分大小写或重 音。要实现这一点,你需要选择合适的LOCALE设置 在此处将排序规则设为非确定性。

非确定性排序规则仅受 ICU 提供者支持。

rules #

指定额外的定制规则,以自定义该排序规则的行为。这仅受 ICU 支持。 详见 Section 23.2.3.4

version #

指定随该排序规则存储的版本字符串。通常应省略该选项,这样版本就会 根据操作系统提供的该排序规则实际版本来计算。此选项旨在供 pg_upgrade从现有安装中复制版本时使用。

另见ALTER COLLATION,了解如何处理排序规则版本 不匹配的问题。

existing_collation #

要复制的现有排序规则的名称。新的排序规则将具有与现有排序规则相同 的属性,但它是一个独立对象。

注解

CREATE COLLATION会在pg_collation 系统目录上获取一个SHARE ROW EXCLUSIVE锁。该锁是 自冲突的,因此一次只能运行一条CREATE COLLATION 命令。

使用DROP COLLATION可移除用户定义的排序规则。

关于如何创建排序规则的更多信息,见Section 23.2.2.3

使用libc排序规则提供者时,区域设置必须适用于当 前数据库编码。有关精确规则,请参见CREATE DATABASE

示例

从操作系统区域设置fr_FR.utf8创建一种排序规则(假定 当前数据库编码是UTF8):

CREATE COLLATION french (locale = 'fr_FR.utf8');

使用 ICU 提供者并采用德语电话簿排序顺序创建一种排序规则:

CREATE COLLATION german_phonebook (provider = icu, locale = 'de-u-co-phonebk');

使用 ICU 提供者、基于 ICU 根区域设置并带有自定义规则创建一种排序规 则:

CREATE COLLATION custom (provider = icu, locale = 'und', rules = '&V << w <<< W');

关于规则语法的更多细节和示例,见Section 23.2.3.4

通过复制现有排序规则来创建一种排序规则:

CREATE COLLATION german FROM "de_DE";

这样在应用程序中使用与操作系统无关的排序规则名称会比较方便。

兼容性

在 SQL 标准中有一个CREATE COLLATION 语句,但它仅限于复制现有排序规则。创建新排序规则的语法是 PostgreSQL扩展。

提交更正

如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。