如何在Django中通过prefetch_related过滤具有多个条件的反向外键
How to filter reverse foreign key with more one conditions by prefetch_related in Django
我创建了两个模型
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 中得到了字段 isAcitve
is Flase
的所有组。
现在,我想在 MemberModel 中获取字段 isActive
为 False
且 country
为 CN
的所有组。
我运行
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'}]}]
我能做什么?
您还应该过滤 GroupModel
,因此:
queryset = GroupModel.objects.prefetch_related(
Prefetch("members", MemberModel.objects.filter(isActive=False, country='CN'))
).filter(
<strong>members__isActive=False, members__country='CN'</strong>
).distinct()
我创建了两个模型
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 中得到了字段 isAcitve
is Flase
的所有组。
现在,我想在 MemberModel 中获取字段 isActive
为 False
且 country
为 CN
的所有组。
我运行
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'}]}]
我能做什么?
您还应该过滤 GroupModel
,因此:
queryset = GroupModel.objects.prefetch_related(
Prefetch("members", MemberModel.objects.filter(isActive=False, country='CN'))
).filter(
<strong>members__isActive=False, members__country='CN'</strong>
).distinct()