1
计数我有以下工作代码:Django的过滤基于相关模型
houses_of_agency = House.objects.filter(agency_id=90)
area_list = AreaHouse.objects.filter(house__in=houses_of_agency).values('area')
area_ids = Area.objects.filter(area_id__in=area_list).values_list('area_id', flat=True)
返回与area_ids列表的查询集。我想进一步过滤,以便只有属于该代理机构的房屋超过100间的情况下才能获得area_ids。
我尝试了以下调整:
houses_of_agency = House.objects.filter(agency_id=90)
area_list = AreaHouse.objects.filter(house__in=houses_of_agency).annotate(num_houses=Count('house_id')).filter(num_houses__gte=100).values('area')
area_ids = Area.objects.filter(area_id__in=area_list).values_list('area_id', flat=True)
但它返回一个空的查询集。
我的模型(简体)是这样的:
class House(TimeStampedModel):
house_pk = models.IntegerField()
agency = models.ForeignKey(Agency, on_delete=models.CASCADE)
class AreaHouse(TimeStampedModel):
area = models.ForeignKey(Area, on_delete=models.CASCADE)
house = models.ForeignKey(House, on_delete=models.CASCADE)
class Area(TimeStampedModel):
area_id = models.IntegerField(primary_key=True)
parent = models.ForeignKey('self', null=True)
name = models.CharField(null=True, max_length=30)
编辑:我使用MySQL数据库后端。
其实它似乎工作。 num_houses始终为1,因此不会给出该区域的实际房屋数量。 – Wessi
那么它的工作呢? – olieidel
这是一个错字。它不起作用。 num_houses等于1,并没有给出该地区房屋的实际数量 – Wessi