PostgreSQLLa base de données la plus sophistiquée au monde.
Documentation PostgreSQL 17.1 » Internes » Catalogues système » pg_enum

51.20. pg_enum #

Le catalogue système pg_enum contient des entrées indiquant les valeurs et labels de chaque type enum. La représentation interne d'une valeur enum donnée est en fait l'OID de sa ligne associée dans pg_enum.

Tableau 51.20. Colonnes de pg_enum

Type

Description

oid oid

Identifiant de ligne

enumtypid oid (référence pg_type.oid)

OID de l'entrée pg_type correspondant à cette valeur d'enum

enumsortorder float4

La position de tri de cette valeur enum dans son type enum

enumlabel name

Le label texte pour cette valeur d'enum


Les OID des lignes de pg_enum suivent une règle spéciale : les OID pairs sont garantis triés de la même façon que l'ordre de tri de leur type enum. Autrement dit, si deux OID pairs appartiennent au même type enum, l'OID le plus petit doit avoir la plus petite valeur dans la colonne enumsortorder. Les valeurs d'OID impaires n'ont pas d'ordre de tri. Cette règle permet que les routines de comparaison d'enum évitent les recherches dans les catalogues dans la plupart des cas standards. Les routines qui créent et modifient les types enum tentent d'affecter des OID paires aux valeurs enum tant que c'est possible.

Quand un type enum est créé, ses membres sont affectés dans l'ordre des positions 1..n. Les membres ajoutés par la suite doivent se voir affecter des valeurs négatives ou fractionnelles de enumsortorder. Le seul prérequis pour ces valeurs est qu'elles soient correctement triées et uniques pour chaque type enum.