注意:由于生产环境的限制,我现在必须坚持django-1.4
。
我刚刚做了一个测试,看看当ManyToMany发生变化时我是否可以挂钩事件。
我有一个Group
模型,其中包含多个Item
个对象。每当项目在任何组中发生变化时,我都想对相关的Group`实例做一些事情。
from django.db import models
from django.db.models.signals import m2m_changed, post_delete, pre_delete
class Item(models.Model):
name = models.CharField(max_length=32)
def __str__(self):
return self.name
class Group(models.Model):
name = models.CharField(max_length=32)
items = models.ManyToManyField(to=Item)
def items_changed(signal, sender, action, instance, reverse, model, pk_set, using, **kwargs):
print str(signal)
print action, instance, reverse, pk_set
m2m_changed.connect(items_changed, sender=Group.items.through)
如果我更改items
个实例上的Group
列表,m2m_changed
事件显然会被解雇。
>>> from sandbox.core.models import Group, Item
>>> item, created = Item.objects.get_or_create(name='f')
>>> g = Group.objects.get(pk=1)
>>> g.items.add(item)
pre_add Group object False set([5])
post_add Group object False set([5])
>>> g.items.remove(item)
pre_remove Group object False set([5])
post_remove Group object False set([5])
现在,当我删除关系的Item
末尾时,没有任何反应,但关系表条目被正确删除。
>>> item.delete()
我尝试通过表连接到m2m的删除信号,但显然,不会为自动关系表触发信号。
在我的models.py
模块中连接如下:
def group_items_pre_delete(signal, sender, instance, using, **kwargs):
print 'pre_delete', instance
def group_items_post_delete(signal, sender, instance, using, **kwargs):
print 'post_delete', instance
pre_delete.connect(group_items_pre_delete, sender=Group.items.through)
post_delete.connect(group_items_post_delete, sender=Group.items.through)
我现在的解决方案是手动检查更改。模型通过REST API公开,所以我可以在更新请求结束时执行此操作(但我希望通过信号自动完成)。
在任何较新版本的Django中是否会触发这些“丢失”信号?