Django 1.9 在列表中查找属性等于某个值的对象
Posted
技术标签:
【中文标题】Django 1.9 在列表中查找属性等于某个值的对象【英文标题】:Django 1.9 Find object in list that has attribute equal to some value 【发布时间】:2016-05-01 03:03:48 【问题描述】:我想知道如何查询属性等于某个给定值的所有餐厅,以及交付区域属性列表中的其他给定值。 这是我的代码的外观:
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'
)
【问题讨论】:
【参考方案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
)
【讨论】:
太棒了!如果这解决了问题,请务必按我答案左侧的“检查”标记,以便任何需要帮助的人都知道答案【参考方案2】:您可以使用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
的可能列表很长的情况下。
【讨论】:
以上是关于Django 1.9 在列表中查找属性等于某个值的对象的主要内容,如果未能解决你的问题,请参考以下文章