Django 1.9 在列表中查找属性等于某个值的对象
Django 1.9 Find object in list that has attribute equal to some value
我想知道如何查询属性等于某个给定值的所有餐厅,以及送货区属性列表中的其他给定值。
这是我的代码的样子:
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'
)
听起来您正在寻找的是 __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
)
您可以通过使用 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
的可能列表很长时。
我想知道如何查询属性等于某个给定值的所有餐厅,以及送货区属性列表中的其他给定值。 这是我的代码的样子:
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'
)
听起来您正在寻找的是 __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
)
您可以通过使用 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
的可能列表很长时。