在delete()方法之前有任何方法来大容量清除对象关系吗?我有个模特:
class Man(models.Model):
girlfriends = model.ManyToManyField('Girl')并希望删除views.py中的所有"Man“对象:
def delete_all_objects(request):
men = Man.objects.all()
#trying to clear objects. getting an error
men.girlfriends.clear()
men.delete()
return HttpResponse("success")获取错误:“QuerySet”对象没有属性“女友”。
发布于 2015-03-04 14:41:51
错误是正确的,查询集没有“女朋友”属性。这是因为queryset是一组Man对象,每个对象都具有以下属性
def delete_all_objects(request):
men = Man.objects.all()
for man in men:
man.girlfriends.clear()
man.delete()
return HttpResponse('success')我还没有测试过这个,但是它应该非常接近你所需要的。
发布于 2015-03-04 14:42:35
除非你也试图删除所有相关的女孩,men.delete()将完全实现你想要的。中间表有一个指向Man的外键,删除对象在默认情况下将删除指向它的所有外键(除非覆盖on_delete行为)。
https://stackoverflow.com/questions/28856417
复制相似问题