Перейти к основному содержимому

pg_collation

Каталог pg_collation описывает доступные колации, которые по сути являются отображениями имени SQL на категории локали операционной системы.

СтолбецТип данныхОписание
oidoidИдентификатор строки
collnamenameИмя колляции (уникальное для пространства имен и кодировки)
collnamespaceoid (ссылается на pg_namespace.oid)OID пространства имен, содержащего данную коллизию
collowneroid (ссылается на pg_authid.oid)Владелец колляции
collprovidercharПоставщик кодировки: d = база данных по умолчанию, c = libc, i = icu
collisdeterministicboolЯвляется ли свертка детерминированной?
collencodingint4Кодировка, в которой применяется коллизия, или -1, если она работает в любой кодировке
collcollatetextLC_COLLATE для данного объекта collation
collctypetextLC_CTYPE для данного объекта collation
colliculocalecolliculocale Идентификатор локали ICU для данного объекта collation
collversiontextВерсия свертки для конкретного поставщика. Она записывается при создании свертки и затем проверяется при ее использовании, чтобы обнаружить изменения в определении свертки, которые могут привести к повреждению данных.

Обратите внимание, что уникальным ключом этого каталога является (collname, collencoding, collnamespace), а не просто (collname, collnamespace). PostgreSQL обычно игнорирует все collations, у которых collencodingне равен либо кодировке текущей базы данных, либо -1, и создание новых записей с тем же именем, что и запись с collencoding = -1, запрещено. Поэтому для идентификации колляции достаточно использовать квалифицированное SQL-имя (schema.name), даже если оно не является уникальным в соответствии с определением каталога. Причина такого определения каталога заключается в том, что initdb заполняет его при инициализации кластера записями для всех локалей, доступных в системе, поэтому он должен быть способен содержать записи для всех кодировок, которые могут когда-либо использоваться в кластере.

В базе данных template0 может быть полезно создавать коллизии, кодировка которых не совпадает с кодировкой базы данных, поскольку они могут совпадать с кодировками баз данных, позднее клонированных из template0. В настоящее время это приходится делать вручную.