CREATE EXTENSION

CREATE EXTENSION — installe une nouvelle extension

Synopsis

CREATE EXTENSION [ IF NOT EXISTS ] nom_extension
    [ WITH ] [ SCHEMA nom_schema ]
             [ VERSION version ]
             [ FROM ancienne_version ]

Description

CREATE EXTENSION charge une nouvelle extension dans la base de donnée courante. Il ne doit pas y avoir d'extension déjà chargée portant le même nom.

Charger une extension consiste essentiellement à exécuter le script de l'extension. Ce script va créer dans la plupart des cas de nouveaux objets SQL comme des fonctions, des types de données, des opérateurs et des méthodes d'indexation. La commande CREATE EXTENSION enregistre en supplément les identifiants de chacun des objets créés, permettant ainsi de les supprimer lorsque la commande DROP EXTENSION est appelée.

Le chargement d'une extension nécessite les mêmes droits que ceux qui permettent la création de ses objets. La plupart des extensions nécessitent ainsi des droits superutilisateur ou d'être le propriétaire de la base de donnée. L'utilisateur qui lance la commande CREATE EXTENSION devient alors le propriétaire de l'extension (une vérification ultérieure des droits permettra de le confirmer) et le propriétaire de chacun des objets créé par le script de l'extension.

Paramètres

IF NOT EXISTS

Permet de ne pas retourner d'erreur si une extension de même nom existe déjà. Un simple message d'avertissement est alors rapporté. À noter que l'extension existante n'a potentiellement aucun lien avec l'extension qui aurait pu être créée.

nom_extension

Le nom de l'extension à installer. PostgreSQL™ créera alors l'extension en utilisant les instructions du fichier de contrôle SHAREDIR/extension/nom_extension.control .

nom_schema

Le nom du schéma dans lequel installer les objets de l'extension, en supposant que l'extension permette de déplacer ses objets dans un autre schéma. Le schéma en question doit exister au préalable. Si ce nom n'est pas spécifié et que le fichier de contrôle de l'extension ne spécifie pas de schéma, le schéma par défaut en cours sera utilisé.

version

La version de l'extension à installer. Il peut s'agir d'un identifiant autant que d'une chaîne de caractère. La version par défaut est celle spécifiée dans le fichier de contrôle de l'extension.

ancienne_version

L'option FROM ancienne_version doit être spécifiée si et seulement s'il s'agit de convertir un module ancienne génération (qui est en fait une simple collection d'objets non empaquetée) en extension. Cette option modifie le comportement de la commande CREATE EXTENSION pour exécuter un script d'installation alternatif qui incorpore les objets existant dans l'extension, plutôt que de créer de nouveaux objets. Il faut prendre garde à ce que SCHEMA spécifie le schéma qui contient ces objets pré-existant.

La valeur à utiliser pour le paramètre ancienne_version est déterminée par l'auteur de l'extension et peut varier s'il existe plus d'une version du module ancienne génération qui peut évoluer en une extension. Concernant les modules additionnels fournis en standard avant PostgreSQL™ 9.1, il est nécessaire d'utiliser la valeur unpackaged pour le paramètre ancienne_version pour les faire évoluer en extension.

Notes

Avant d'utiliser la commande CREATE EXTENSION pour charger une extension dans une base de données, il est nécessaire d'installer les fichiers qui l'accompagnent. Les informations de Modules supplémentaires fournis permettent d'installer les extensions fournies avec PostgreSQL™.

Les extensions disponibles à l'installation sur le serveur peuvent être identifiées au moyen des vues systèmes pg_available_extensions et pg_available_extension_versions.

Pour obtenir des informations sur l'écriture de nouvelles extensions, consultez Section 35.15, « Empaqueter des objets dans une extension ».

Exemples

Installer l'extension hstore dans la base de données courante :

CREATE EXTENSION hstore;

Mettre à jour le module pré-9.1 hstore sous la forme d'une extension :

CREATE EXTENSION hstore SCHEMA public FROM unpackaged;

Prenez garde à bien spécifier le schéma vers lequel vous souhaitez installer les objets de hstore.

Compatibilité

La commande CREATE EXTENSION est spécifique à PostgreSQL™.

Voir aussi

ALTER EXTENSION(7), DROP EXTENSION(7)