PostgreSQL
 sql >> Base de Dados >  >> RDS >> PostgreSQL

Django emula o comportamento do gatilho do banco de dados na inserção/atualização/exclusão em massa


Primeiro, em vez de substituir salvar para adicionar __before e __after métodos, você pode usar o built-in pre_save , post_save, pre_delete, e post_delete sinais. 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 será acionado quando você chamar delete() em um conjunto de consultas.

No entanto, para atualização em massa, você terá que chamar manualmente a função que deseja acionar. E você pode jogar tudo em uma transação também.

Para chamar a função de gatilho adequada se estiver usando modelos dinâmicos, você pode inspecionar o ContentType do modelo. Por exemplo:
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)