PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Django emula il comportamento del trigger del database in caso di inserimento/aggiornamento/eliminazione in blocco

Innanzitutto, invece di sovrascrivere salva per aggiungere __before e __after metodi, puoi usare il built-in pre_save , post_save, pre_delete, e post_delete segnali. https://docs.djangoproject.com/en/1.4/topics/signals/

from django.db.models.signals import post_save

class YourModel(models.Model):
    pass

def after_save_your_model(sender, instance, **kwargs):
     pass

# register the signal
post_save.connect(after_save_your_model, sender=YourModel, dispatch_uid=__file__)

pre_delete e post_delete verrà attivato quando chiami delete() su un set di query.

Per l'aggiornamento in blocco, tuttavia, dovrai chiamare manualmente la funzione che desideri attivare. E puoi anche inserire tutto in una transazione.

Per chiamare la corretta funzione di trigger se stai usando modelli dinamici, puoi controllare il ContentType del modello. Ad esempio:

from django.contrib.contenttypes.models import ContentType

def view(request, app, model_name, method):
    ...
    model = get_model(app, model_name)
    content_type = ContentType.objects.get_for_model(model)
    if content_type == ContenType.objects.get_for_model(YourModel):
        after_save_your_model(model)
    elif content_type == Contentype.objects.get_for_model(AnotherModel):
        another_trigger_function(model)