Django 1.9在列表中查找属性等于某个值的对象

时间:2016-01-24 21:41:18

标签: python django django-models manytomanyfield

我想知道如何对所有具有等于某个给定值的属性的餐馆以及交付区域列表中的其他给定值属性进行查询。 以下是我的代码:

models.py

class Restaurant(models.Model):
    name = models.CharField(max_length=120)
    delivery_zones = models.ManyToManyField('DeliveryZone', default=None)
    service_type = models.CharField(max_length=25, choices=settings.SERVICE_TYPE_CHOICES, default='DELIVERY')
    is_active = models.BooleanField(default=False)

class DeliveryZones(models.Model):
    zone = models.CharField(max_length=25, default=None)
    is_active = models.BooleanField(default=False)

views.py:

restaurants = get_list_404(
    Restaurant, is_active=True,
    service_type='SOME_GIVEN_SERVICE_TYPE_NAME',
    delivery_zones__icontains='SOME_GIVEN_ZONE_NAME'
)

2 个答案:

答案 0 :(得分:1)

您正在寻找的是__in查找。此外,它是get_list_or_404,而不是get_list_404

尝试:

zones = DeliveryZones.objects.filter(zone='SOME_NAME', is_active=True)
restaurants = get_list_or_404(
    Restaurant, is_active=True,
    service_type='SOME_GIVEN_SERVICE_TYPE_NAME',
    delivery_zones__in=zones
)

答案 1 :(得分:0)

您可以在一个查询中执行此操作,这意味着使用lookup that spans a relationship点击单个数据库:

restaurants = get_list_or_404(
    Restaurant, is_active=True,
    service_type='SOME_GIVEN_SERVICE_TYPE_NAME',
    delivery_zones__name='SOME_GIVEN_ZONE_NAME'
)

这会更有效率,特别是如果DeliveryZones的可能列表很长。