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

Django emula el comportamiento del activador de la base de datos en la inserción/actualización/eliminación masiva

Primero, en lugar de anular guardar para agregar __before y __after métodos, puede usar el pre_save incorporado , post_save, pre_delete, y post_delete señales 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 y post_delete se activará cuando llame a delete() en un conjunto de consultas.

Sin embargo, para la actualización masiva, deberá llamar manualmente a la función que desea activar. Y también puede incluirlo todo en una transacción.

Para llamar a la función de activación adecuada si usa modelos dinámicos, puede inspeccionar el tipo de contenido del modelo. Por ejemplo:

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)