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

51.7. pg_attribute

Le catalogue pg_attribute stocke les informations concernant les colonnes des tables. Il y a exactement une ligne de pg_attribute par colonne de table de la base de données. (Il y a aussi des attributs pour les index et, en fait, tous les objets qui possèdent des entrées dans pg_class.)

Le terme attribut, équivalent à colonne, est utilisé pour des raisons historiques.

Tableau 51.7. Colonnes de pg_attribute

NomTypeRéférencesDescription
attrelidoidpg_class.oidLa table à laquelle appartient la colonne
attnamename Le nom de la colonne
atttypidoidpg_type.oidLe type de données de la colonne
attstattargetint4  Contrôle le niveau de détail des statistiques accumulées pour la colonne par ANALYZE. Une valeur 0 indique qu'aucune statistique ne doit être collectée. Une valeur négative indique d'utiliser l'objectif de statistiques par défaut. Le sens exact d'une valeur positive dépend du type de données. Pour les données scalaires, attstattarget est à la fois le nombre de « valeurs les plus courantes » à collecter et le nombre d'histogrammes à créer.
attlenint2  Une copie de pg_type.typlen pour le type de la colonne.
attnumint2  Le numéro de la colonne. La numérotation des colonnes ordinaires démarre à 1. Les colonnes système, comme les ctid, ont des numéros négatifs arbitraires.
attndimsint4  Nombre de dimensions, si la colonne est de type tableau, sinon 0. (Pour l'instant, le nombre de dimensions des tableaux n'est pas contrôlé, donc une valeur autre que 0 indique que « c'est un tableau ».)
attcacheoffint4  Toujours -1 sur disque, mais peut être mis à jour lorsque la ligne est chargée en mémoire, pour mettre en cache l'emplacement de l'attribut dans la ligne.
atttypmodint4  Stocke des données spécifiques au type de données précisé lors de la création de la table (par exemple, la taille maximale d'une colonne de type varchar). Il est transmis aux fonctions spécifiques au type d'entrée de données et de vérification de taille. La valeur est généralement -1 pour les types de données qui n'ont pas besoin de atttypmod.
attbyvalbool  Une copie de pg_type.typbyval du type de la colonne.
attstoragechar  Contient normalement une copie de pg_type.typstorage du type de la colonne. Pour les types de données TOASTables, cette valeur peut être modifiée après la création de la colonne pour en contrôler les règles de stockage.
attalignchar  Une copie de pg_type.typalign du type de la colonne.
attnotnullbool  Indique une contrainte de non-nullité de colonne. Il est possible de changer cette colonne pour activer ou désactiver cette contrainte.
atthasdefbool  Cette colonne a une expression par défaut ou une expression générée, auquel cas il y aura un enregistrement correspondant dans le catalogue pg_attrdef qui définit réellement l'expression. (Vérifiez attgenerated pour déterminer si c'est une expression par défaut ou générée.)
atthasmissingbool  Cette colonne a une valeur qui est utilisée quand la colonne est complètement manquante de la ligne, ce qui arrive quand une colonne est ajoutée avec une valeur par défaut et non volatile (contrainte DEFAULT) après la création de la ligne. La valeur actuellement utilisée est enregistrée dans la colonne attmissingval.
attidentitychar  Si vide (''), alors ce n'est pas une colonne identité. Sinon, a signifie toujours généré alors que d signifie généré par défaut.
attgeneratedchar  Si c'est un octet zéro (''), alors ce n'est pas une colonne générée. Sinon, s = stockée. (D'autres valeurs pourraient être ajoutées dans le futur.)
attisdroppedbool  Indique que la colonne a été supprimée et n'est plus valide. Une colonne supprimée est toujours présente physiquement dans la table, mais elle est ignorée par l'analyseur de requête et ne peut être accédée en SQL.
attislocalbool  La colonne est définie localement dans la relation. Une colonne peut être simultanément définie localement et héritée.
attinhcountint4  Nombre d'ancêtres directs de la colonne. Une colonne qui a au moins un ancêtre ne peut être ni supprimée ni renommée.
attcollationoidpg_collation.oid Le collationnement défini de la colonne, ou zéro si la colonne n'est pas un type de données collationnable.
attaclaclitem[]  Droits d'accès niveau colonne, s'il y en a qui ont été spécifiquement accordés à cette colonne
attoptionstext[]  Options au niveau colonne, en tant que chaînes du type « motclé=valeur »
attfdwoptionstext[]  Options du wrapper de données distances, au niveau colonne, en tant que chaînes du type « keyword=value »
attmissingvalanyarray  Cette colonne a un tableau à un élément contenant la valeur utilisée quand la colonne est complètement manquante de la ligne, comme cela peut survenir quand la colonne est ajoutée avec une valeur par défaut (DEFAULT) non volatile après la création de la ligne. La valeur est seulement utilisée quand atthasmissing est true. S'il n'y a pas de valeur, la colonne est NULL.

Dans l'entrée pg_attribute d'une colonne supprimée, atttypid est réinitialisée à 0 mais attlen et les autres champs copiés à partir de pg_type sont toujours valides. Cet arrangement est nécessaire pour s'adapter à la situation où le type de données de la colonne supprimée a été ensuite supprimé et qu'il n'existe donc plus de ligne pg_type. attlen et les autres champs peuvent être utilisés pour interpréter le contenu d'une ligne de la table.