CREATE TYPE |
Crée un type |
---|---|
PostgreSQL |
Syntaxe
CREATE TYPE name AS ( [ attribute_name data_type [ COLLATE collation ] [, ... ] ] ) |
CREATE TYPE name AS ENUM ( [ 'label' [, ... ] ] ) |
CREATE TYPE name AS RANGE ( SUBTYPE = subtype [ , SUBTYPE_OPCLASS = subtype_operator_class ] [ , COLLATION = collation ] [ , CANONICAL = canonical_function ] [ , SUBTYPE_DIFF = subtype_diff_function ] ) |
CREATE TYPE name ( INPUT = input_function, OUTPUT = output_function [ , RECEIVE = receive_function ] [ , SEND = send_function ] [ , TYPMOD_IN = type_modifier_input_function ] [ , TYPMOD_OUT = type_modifier_output_function ] [ , ANALYZE = analyze_function ] [ , INTERNALLENGTH = { internallength | VARIABLE } ] [ , PASSEDBYVALUE ] [ , ALIGNMENT = alignment ] [ , STORAGE = storage ] [ , LIKE = like_type ] [ , CATEGORY = category ] [ , PREFERRED = preferred ] [ , DEFAULT = default ] [ , ELEMENT = element ] [ , DELIMITER = delimiter ] [ , COLLATABLE = collatable ] ) |
CREATE TYPE name |
Paramètres
Nom | Description |
---|---|
name | Ce paramètre permet d'indiquer le nom (éventuellement qualifié par le schéma) d'un type à créer. |
attribute_name | Ce paramètre permet d'indiquer le nom d'un attribut (colonne) pour le type composite. |
data_type | Ce paramètre permet d'indiquer le nom d'un type de données existant pour devenir une colonne du type composite. |
collation | Ce paramètre permet d'indiquer le nom d'un classement existant à associer à une colonne de type composite ou à un type d'intervalle. |
label | Ce paramètre permet d'indiquer un littéral de chaîne de caractères représentant l'étiquette textuelle associée à une valeur d'un type enum. |
subtype | Ce paramètre permet d'indiquer le nom du type d'élément dont le type d'intervalle représentera les intervalles. |
subtype_operator_class | Ce paramètre permet d'indiquer le nom d'une classe d'opérateur B-tree pour le sous-type. |
canonical_function | Ce paramètre permet d'indiquer le nom de la fonction de canonisation pour le type de l'intervalle. |
subtype_diff_function | Ce paramètre permet d'indiquer le nom d'une fonction de différence pour le sous-type. |
input_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant les données de la forme textuelle externe du type en sa forme interne. |
output_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant les données de la forme interne du type en sa forme textuelle externe. |
receive_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant les données de la forme binaire externe du type en sa forme interne. |
send_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant les données de la forme interne du type en sa forme binaire externe. |
type_modifier_input_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant un tableau de modificateur(s) pour le type en forme interne. |
type_modifier_output_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant la forme interne du ou des modificateurs du type en forme textuelle externe. |
analyze_function | Ce paramètre permet d'indiquer le nom d'une fonction convertissant une analyse statistique pour le type de données. |
internallength | Ce paramètre permet d'indiquer une constante numérique spécifiant la longueur en octets de la représentation interne du nouveau type. L'hypothèse par défaut est qu'il est de longueur variable. |
alignment | Ce paramètre permet d'indiquer l'exigence d'alignement d'entreposage du type de données. S'il est spécifié, il doit être char, int2, int4 ou double ; la valeur par défaut est int4. |
storage | Ce paramètre permet d'indiquer la stratégie d'entreposage pour le type de données. Si spécifié, doit être simple, externe, étendu ou principal ; la valeur par défaut est simple. |
like_type | Ce paramètre permet d'indiquer le nom d'un type de données existant dont le nouveau type aura la même représentation. Les valeurs de internallength, passbyvalue, d'alignement et d'entreposage sont copiées à partir de ce type, à moins qu'elles ne soient remplacées par une spécification explicite ailleurs dans cette commande CREATE TYPE. |
category | Ce paramètre permet d'indiquer le code de catégorie (un seul caractère ASCII) pour ce type. La valeur par défaut est «U» pour «type défini par l'utilisateur». Vous pouvez également choisir d'autres caractères ASCII afin de créer des catégories personnalisées. |
preferred | Ce paramètre permet d'indiquer True si ce type est un type préféré dans sa catégorie de type, sinon False. Le défaut est False. Soyez très prudent lorsque vous créez un nouveau type préféré dans une catégorie de type existante, car cela pourrait entraîner des changements de comportement surprenants. |
default | Ce paramètre permet d'indiquer la valeur par défaut pour le type de données. S'il est omis, la valeur par défaut est null. |
element | Ce paramètre permet d'indiquer le type en cours de création est un tableau ; ceci spécifie le type des éléments du tableau. |
delimiter | Ce paramètre permet d'indiquer le caractère délimiteur à utiliser entre les valeurs des tableaux constitués de ce type. |
collatable | Ce paramètre permet d'indiquer True si les opérations de ce type peuvent utiliser des informations de classement. Le défaut est False. |
Description
Cette instruction permet de définir un nouveau type de données.
Dernière mise à jour : Jeudi, le 14 Octobre 2021