使用ManyToMany关系从Django中的QuerySet列表中删除对象

时间:2016-09-06 16:33:46

标签: python django postgresql

在Django中使用ForeignKeyManyToMany关系时,我无法从对象列表中删除对象。

以下是我为物品,清单和订单(中间模型)设置的模型。

class Item(models.Model):
    title_english = models.CharField(max_length=250)
    url = models.CharField(max_length=250)
    img_url = models.CharField(max_length=250)

    def __unicode__(self):
        return self.title_english

class List(models.Model):
    slides = models.ManyToManyField(Item, through='Order')
    size = models.PositiveIntegerField(default=0)

    def incrementSize(self):
        self.size = self.size+1

    def __unicode__(self):
        return "List: " + str(self.slides.all())

class Order(models.Model):
    item = models.ForeignKey(Item, on_delete=models.CASCADE)
    list = models.ForeignKey(List, on_delete=models.CASCADE)
    index = models.PositiveIntegerField()

    def __unicode__(self):
        return str(index) + ": " + str(self.item)

    def appendItemToList(self, item, list):
        self.item = item
        self.list = list
        self.index = list.size
        list.incrementSize()

我正在向列表添加对象(从现有对象动态创建),通过如下视图:

def AddItem(request, pk):
    sourceObj = SourceObject.objects.get(pk=pk)
    lst = List.objects.all()
    if not lst:
        lst = List()
        lst.save()
    else:
        lst = lst[0]
    item = Item(title_english=sourceObj.name_english,  url=sourceObj.slug, img_url=sourceObj.media)
    item.save()
    order = Order()
    order.appendItemToList(item, lst)
    order.save()
    lst.save()
    return redirect("some_url")

现在我的问题是,删除添加到list的项目。我无法理解如何访问目标对象。

def RemoveItem(request, pk):
    lst = List.objects.all()
    lst.delete() #deletes the entire list
    #how do I access the target object from here to delete it
    return redirect("some_url")

我通读了Django文档,指的是"以后的关系"在这里:https://docs.djangoproject.com/en/dev/topics/db/queries/#backwards-related-objects

但我无法找到有效的解决方案。

注意:我使用的是Django 1.5和Python 2.7

1 个答案:

答案 0 :(得分:3)

如果您的目标是来自' pk'你可以使用List.objects.get(pk).delete()。

一定要把它放在试试中:除了List.DoesNotExist:避免人们通过在URL中手动输入随机字符串来分隔500个。

try:
  List.objects.get(pk).delete()
except List.DoesNotExist:
  do_something_when_item_does_not_exist()
return redirect("some_url")

另一种选择是使用' get_object_or_404'函数来检索项目,如果URL中给出的项目不存在,这将引发http404异常,这在我看来是有道理的。

item = get_object_or_404(List, pk)
item.delete()
return redirect("some_url")

如果您要在特定列表中查找特定项目,则您的URL和视图中需要两个参数

URL:

url(r'^(?P<list_id>[\d]+)/(?P<item_id>[\d]+)/delete$', delete, name='whatever')

视图:

def delete(request, list_id, item_id):
  item = get_object_or_404(List, pk=item_id, list_id=list_id)
  item.delete()
  return redirect("some_url")