Opérations de migration de base de données

Toutes ces opérations sont disponibles dans le module django.contrib.postgres.operations.

Création d’extension à l’aide des migrations

Il est possible de créer une extension de base de données PostgreSQL en utilisant un fichier de migration. Cet exemple crée une extension hstore, mais le même principe est applicable aux autres extensions.

Configurer l’extension hstore dans PostgreSQL avant la première opération CreateModel ou AddField qui concerne un champ HStoreField en ajoutant une migration comprenant l’opération HStoreExtension. Par exemple :

from django.contrib.postgres.operations import HStoreExtension

class Migration(migrations.Migration):
    ...

    operations = [
        HStoreExtension(),
        ...
    ]

La création de l’extension exige un utilisateur de base de données possédant les droits de superutilisateur. Si l’utilisateur de base de données Django ne possède pas ces privilèges, il est alors nécessaire de créer l’extension en dehors des migrations Django avec un utilisateur qui possède les droits requis. Dans ce cas, connectez-vous à la base de données et lancez la requête CREATE EXTENSION IF NOT EXISTS hstore;.

CreateExtension

class CreateExtension(name)[source]

Une sous-classe d”Operation qui installe des extensions PostgreSQL.

name

Ce paramètre est obligatoire. Le nom de l’extension à installer.

BtreeGinExtension

class BtreeGinExtension[source]

Installe l’extension btree_gin.

BtreeGistExtension

class BtreeGistExtension[source]
New in Django 2.0:

Installe l’extension btree_gist.

CITextExtension

class CITextExtension[source]

Installe l’extension citext.

CryptoExtension

class CryptoExtension[source]
New in Django 2.0:

Installe l’extension pgcrypto.

HStoreExtension

class HStoreExtension[source]

Installe l’extension hstore et configure également la connexion afin d’interpréter les données hstore pour un usage possible dans les migrations suivantes.

TrigramExtension

class TrigramExtension[source]

Installe l’extension pg_trgm.

UnaccentExtension

class UnaccentExtension[source]

Installe l’extension unaccent.

Back to Top