如何通过Django中的prefetch_related过滤具有多个条件的反向外键

Posted

技术标签:

【中文标题】如何通过Django中的prefetch_related过滤具有多个条件的反向外键【英文标题】:How to filter reverse foreign key with more one conditions by prefetch_related in Django 【发布时间】:2021-11-17 06:58:55 【问题描述】:

我创建了两个模型

class GroupModel(models.Model):
    group_name = models.CharField(max_length=2, null=False, default="A")

class MemberModel(models.Model):
    name = models.CharField(max_length=8, null=False, default="")
    group = models.ForeignKey(
        to=GroupModel,
        on_delete=models.CASCADE,
        related_name="members",
        db_column="member",
    )
    isActive = models.BooleanField(null=False, default=False)
    country = models.CharField(max_length=8, null=False, default="CN")

我跑

queryset = GroupModel.objects.prefetch_related(
    Prefetch("members", MemberModel.objects.filter(isActive=False))
).distinct()

我在 MemberModel 中找到了字段 isAcitveFlase 的所有组。

现在,我想在 MemberModel 中获取字段 isActiveFalsecountryCN 的所有组。

我跑

queryset = GroupModel.objects.prefetch_related(
    Prefetch("members", MemberModel.objects.filter(isActive=False, country="CN"))
).distinct()

但我得到的结果是

['group_name': 'GROUP_A', 'id': 1, 'members': [],
 'group_name': 'GROUP_B', 'id': 2, 'members': [],
 'group_name': 'GROUP_C',
  'id': 3,
  'members': ['country': 'CN', 'isActive': False, 'name': 'ENWK',
              'country': 'CN', 'isActive': False, 'name': 'LKMP']]

我想得到

['group_name': 'GROUP_C',
  'id': 3,
  'members': ['country': 'CN', 'isActive': False, 'name': 'ENWK',
              'country': 'CN', 'isActive': False, 'name': 'LKMP']]

我能做什么?

【问题讨论】:

【参考方案1】:

你也应该过滤GroupModel,所以:

queryset = GroupModel.objects.prefetch_related(
    Prefetch("members", MemberModel.objects.filter(isActive=False, country='CN'))
).filter(
    members__isActive=False, members__country='CN'
).distinct()

【讨论】:

成功了。谢谢

以上是关于如何通过Django中的prefetch_related过滤具有多个条件的反向外键的主要内容,如果未能解决你的问题,请参考以下文章

如何通过关系将复选框值保存到 django 中的 ManyToManyField?

如何通过 django 读取 excel 文件中的复选框值?

如何返回通过django中的视图的静态文件?

如何返回通过django中的视图的静态文件?

如何通过 django 中的contact.html 模板发送电子邮件

如何通过django中的多级反向外键获取相关对象查询集?