sql >> Base de Datos >  >> RDS >> PostgreSQL

Acelere Django y Postgres con un campo JSON simple

Django es compatible con JSONField para PostgreSQL, aquí está el ejemplo

from django.contrib.postgres.fields import JSONField
from django.db import models

class Dog(models.Model):
    name = models.CharField(max_length=200)
    data = JSONField()

    def __str__(self):  # __unicode__ on Python 2
        return self.name

también puede leer más sobre esto en este enlace https://docs.djangoproject.com/en/dev/ref/contrib/postgres/fields/#jsonfield

también puede probar HStoreField en postgresql, HStoreField es más rápido que JSONField, para usar HSTORE necesita habilitar la extensión Hstore en Postgresql

postgres_prompt=> create extension hstore;

en su archivo de migración necesita agregar esto

from django.contrib.postgres.operations import HStoreExtension

class Migration(migrations.Migration):
    ...

    operations = [
        HStoreExtension(),
        ...
    ]

aquí hay un ejemplo del uso de Hstore en sus modelos:

from django.contrib.postgres.fields import HStoreField
from django.db import models

class Dog(models.Model):
    name = models.CharField(max_length=200)
    data = HStoreField()

    def __str__(self):  # __unicode__ on Python 2
        return self.name

para saber más sobre esto ve al l:https://docs.djangoproject.com/en/1.9/ref/contrib/postgres/fields/#hstorefield