如果有任何項目實例不在某個項目列表中,我試圖過濾掉 Quotation 模型中的實例。從 ProjectItem 模型中檢索特定的項目列表。模型結構如下,我會在代碼后面詳細解釋。models.pyclass 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 模型實現的。有什么辦法嗎?感謝大家的幫助,請指導我,如果信息不足請告訴我。
1 回答

慕絲7291255
TA貢獻1859條經驗 獲得超6個贊
您可以過濾:
Quotation.objects.filter(items__item__projectitem__project=project)
您可以使用 來.distinct()
確保每個Quotation
對象只返回一次:
Quotation.objects.filter(items__item__projectitem__project=project).distinct()
如果您希望Quotation
s僅引用project
,您可以使用.exclude(…)
,或者更直接地計算Project
s:
from django.db.models import Count, Q
Quotation.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 查詢此類關系更加方便。ManyToManyField
ManyToManyField
through=…
添加回答
舉報
0/150
提交
取消