猿问

Django - 由于外键模型关系,如何排除查询集中的实例

如果有任何项目实例不在某个项目列表中,我试图过滤掉 Quotation 模型中的实例。从 ProjectItem 模型中检索特定的项目列表。模型结构如下,我会在代码后面详细解释。


models.py


class SalesProject(models.Model):

    sales_project_id = models.AutoField(primary_key=True)

    sales_project_name = models.CharField(max_length=100)


class ProjectItem(models.Model):

    project_item_id = models.AutoField(primary_key=True)

    project = models.ForeignKey('SalesProject', related_name='items', on_delete=models.CASCADE)

    item = models.ForeignKey('Item', on_delete=models.CASCADE)

    remarks = models.TextField(max_length=1000)


class Quotation(models.Model):

    quotation_id = models.AutoField(primary_key=True)

    salesProject = models.ForeignKey(

        'SalesProject', related_name='quotations', on_delete=models.CASCADE, null=True, blank=True)

    details = models.TextField(max_length=1000, blank=True, null=True)


class QuotationItem(models.Model):

    quotation_item_id = models.AutoField(primary_key=True)

    item = models.ForeignKey('Item', on_delete=models.CASCADE, null=True, blank=True)

    quotation = models.ForeignKey('Quotation', on_delete=models.CASCADE, related_name='items', null=True, blank=True)

    remarks = models.TextField(max_length=1000)


class Item(models.Model):

    item_id = models.AutoField(primary_key=True)

    item_code = models.CharField(max_length=500, null=True, blank=True)

    item_description = models.TextField(max_length=1000, null=True, blank=True)

首先,我将通过查询当前的 SalesProject 来获取 Item 实例的列表。(其中项目 = SalesProject 实例)


items = ProjectItem.objects.filter(project=project).values_list('item', flat=True)

基本上,此项目列表中的项目实例是各种“允许的项目”。我想要返回的是仅包含此列表中的 Item 实例的所有 Quotation 实例(或排除包含此列表之外的 Item 实例的任何 Quotation 实例)。Quotation 与 Item 的关系是通过 QuotationItem 模型实现的。有什么办法吗?


感谢大家的帮助,请指导我,如果信息不足请告诉我。


守着一只汪
浏览 138回答 1
1回答

慕丝7291255

您可以过滤:Quotation.objects.filter(items__item__projectitem__project=project)您可以使用 来.distinct()确保每个Quotation对象只返回一次:Quotation.objects.filter(items__item__projectitem__project=project).distinct()如果您希望Quotations仅引用project,您可以使用.exclude(…),或者更直接地计算Projects:from django.db.models import Count, QQuotation.objects.annotate(    nproject=Count('items__item__projectitem__project', distinct=True),    nproject_project=Count(        'items__item__projectitem__project',        distinct=True,        filter=Q(items__item__projectitem__project=project)    ),).filter(    nproject_project=1,    nproject=1).distinct()注意:您的QuotationItem模型基本上就像[Django-doc]的直通模型,您可能想添加一个带有此模型的参数 [Django-doc]。这使得使用 Django ORM 查询此类关系更加方便。ManyToManyFieldManyToManyFieldthrough=…
随时随地看视频慕课网APP

相关分类

Python
我要回答