使用ManytoManyField进行Django查询

问题描述 投票:0回答:1

使用示例代码:

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=128)

    def __str__(self):
        return self.name

class Group(models.Model):
    name = models.CharField(max_length=128)
    members = models.ManyToManyField(Person, through='Membership')

    def __str__(self):
        return self.name

class Membership(models.Model):
    person = models.ForeignKey(Person, on_delete=models.CASCADE)
    group = models.ForeignKey(Group, on_delete=models.CASCADE)
    date_joined = models.DateField()

我如何通过date_joined获取最后5个人的姓名及其组名称顺序?就像是:

"name1" "group1" "19/02/2019"
"name2" "group1" "19/02/2019"
"name1" "group2" "19/02/2019"
"name3" "group1" "18/02/2019"
"name4" "group2" "17/02/2019"

我尝试了很多选项,但我无法做到:S提前谢谢。

django django-models foreign-keys manytomanyfield
1个回答
1
投票

你可以通过以下方式得到这个

Membership.objects.values('person__name', 'group__name', 'date_joined').order_by(date_joined)[:5]
© www.soinside.com 2019 - 2024. All rights reserved.