首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >清除Django中多个对象上的多个对象

清除Django中多个对象上的多个对象
EN

Stack Overflow用户
提问于 2015-03-04 14:01:59
回答 2查看 2.6K关注 0票数 2

在delete()方法之前有任何方法来大容量清除对象关系吗?我有个模特:

代码语言:javascript
复制
class Man(models.Model):
     girlfriends = model.ManyToManyField('Girl')

并希望删除views.py中的所有"Man“对象:

代码语言:javascript
复制
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”对象没有属性“女友”。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-03-04 14:41:51

错误是正确的,查询集没有“女朋友”属性。这是因为queryset是一组Man对象,每个对象都具有以下属性

代码语言:javascript
复制
def delete_all_objects(request):
    men = Man.objects.all()
    for man in men:
        man.girlfriends.clear()
        man.delete()
    return HttpResponse('success')

我还没有测试过这个,但是它应该非常接近你所需要的。

票数 4
EN

Stack Overflow用户

发布于 2015-03-04 14:42:35

除非你也试图删除所有相关的女孩,men.delete()将完全实现你想要的。中间表有一个指向Man的外键,删除对象在默认情况下将删除指向它的所有外键(除非覆盖on_delete行为)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28856417

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档