Documentation PostgreSQL 8.1.23 > Référence > Commandes SQL > CREATE DOMAIN | |
CREATE DATABASE | CREATE FUNCTION |
CREATE DOMAIN nom [AS] type_donnee [ DEFAULT expression ] [ contrainte [ ... ] ] où contrainte est : [ CONSTRAINT nom_contrainte ] { NOT NULL | NULL | CHECK (expression) }
CREATE DOMAIN crée un nouveau domaine de données. L'utilisateur définissant un domaine en devient le propriétaire.
Si un nom de schéma est donné (par exemple, CREATE DOMAIN monschema.mondomaine ...), alors le domaine est créé dans le schéma spécifié. Sinon, il est créé dans le schéma courant. Le nom du domaine doit être unique parmi les types et domaines existant dans son schéma.
Les domaines permettent d'extraire des champs communs à plusieurs tables et de les regrouper en un seul emplacement, ce qui en facilite la maintenance. Par exemple, une colonne adresse de courriel peut être utilisée dans plusieurs tables, avec chaque fois les mêmes propriétés. La définition d'un domaine et son utilisation permet d'éviter de définir les mêmes contraintes sur chaque table.
Actuellement, il est risqué de déclarer un domaine comme valeur de retour d'une fonction parce qu'aucun langage procédural ne teste les contraintes de domaine sur les résultats. C'est au code de la fonction de respecter les contraintes. Avec PL/pgSQL, il est possible de contourner cela en convertissant explicitement la valeur du résultat vers le type du domaine avant de la retourner. PL/pgSQL ne teste pas non plus les contraintes de domaine pour les variables locales internes aux fonctions.
Le nom du domaine à créer (éventuellement qualifié du nom du schéma).
Le type de données sous-jacent au domaine. Il peut contenir des spécifications de tableau.
La clause DEFAULT permet de définir une valeur par défaut pour les colonnes d'un type de données du domaine. La valeur est une expression quelconque sans variable (les sous-requêtes ne sont pas autorisées). Le type de données de l'expression par défaut doit correspondre à celui du domaine. Si la valeur par défaut n'est pas indiquée, alors il s'agit de la valeur NULL.
L'expression par défaut est utilisée dans toute opération d'insertion qui ne spécifie pas de valeur pour cette colonne. Si une valeur par défaut est définie sur une colonne particulière, elle surcharge toute valeur par défaut du domaine. De même, la valeur par défaut surcharge toute valeur par défaut associée au type de données sous-jacent.
Un nom optionnel pour une contrainte. S'il n'est pas spécifié, le système en engendre un.
Les valeurs de ce domaine ne peuvent pas être NULL.
Les valeurs de ce domaine peuvent être NULL. C'est la valeur par défaut.
Cette clause a pour seul but la compatibilité avec les bases de données SQL non standard. Son utilisation est découragée dans les applications nouvelles.
Les clauses CHECK spécifient des contraintes d'intégrité ou des tests que les valeurs du domaine doivent satisfaire. Chaque contrainte doit être une expression produisant un résultat booléen. VALUE est obligatoirement utilisé pour se référer à la valeur testée.
Actuellement, les expressions CHECK ne peuvent ni contenir de sous-requêtes ni se référer à des variables autres que VALUE.
Créer le type de données code_postal_us, et l'utiliser dans la définition d'une table. Un test d'expression rationnelle est utilisé pour vérifier que la valeur ressemble à un code postal US valide.
CREATE DOMAIN code_postal_us AS TEXT CHECK( VALUE ~ '^\\d{5}$' OR VALUE ~ '^\\d{5}-\\d{4}$' ); CREATE TABLE courrier_us ( id_adresse SERIAL NOT NULL PRIMARY KEY , rue1 TEXT NOT NULL , rue2 TEXT , rue3 TEXT , ville TEXT NOT NULL , code_postal code_postal_us NOT NULL );