Le catalogue pg_collation décrit les collationnements disponibles, qui sont essentiellement des correspondances entre un nom SQL et des catégories de locales du système d'exploitation. Voir Section 22.2, « Support des collations » pour plus d'informations.
Tableau 49.13. Colonnes de pg_collation
Nom | Type | Références | Description |
---|---|---|---|
oid | oid | Identifiant de ligne (attribut caché ; doit être sélectionné explicitement) | |
collname | name | Nom du collationnement (unique par schéma et encodage) | |
collnamespace | oid | pg_namespace.oid | L'OID du schéma contenant ce collationnement |
collowner | oid | pg_authid.oid | Propriétaire du collationnement |
collencoding | int4 | Encodage pour lequel le collationnement est disponible. -1 s'il fonctionne pour tous les encodages | |
collcollate | name | LC_COLLATE pour ce collationnement | |
collctype | name | LC_CTYPE pour ce collationnement |
Notez que la clé unique de ce catalogue est (collname, collencoding, collnamespace) et non pas seulement (collname, collnamespace). PostgreSQL™ ignore habituellement tous les collationnement qui n'ont pas de colonne collencoding égale soit à l'encodage de la base de données en cours ou -1. La création de nouvelles entrées de même nom qu'une autre entrée dont collencoding vaut -1 est interdite. Du coup, il suffit d'utiliser un nom SQL qualifié du schéma (schéma.nom) pour identifier un collationnement bien que cela ne soit pas unique d'après la définition du catalogue. Ce catalogue a été défini ainsi car initdb le remplit au moment de l'initialisation de l'instance avec les entrées pour toutes les locales disponibles sur le système, donc il doit être capable de contenir les entrées de tous les encodages qui pourraient être utilisés dans l'instance.
Dans la base de données template0, il pourrait être utile de créer les collationnement dont l'encodage ne correspond pas à l'encodage de la base ded onnées car ils pourraient correspondre aux encodages de bases de données créées par la suite à partir de ce modèle de base de données. Cela doit être fait manuellement actuellement.