如何构造这个 Django ORM 查询集查询?

how to construct this Django ORM queryset query?

我正在尝试确定如何构建查询。我有两个来自外部数据库的模型,我试图将它们导入到不同的模式中。源数据具有三个模型:

class Group(model):
    ...
    name = models.CharField()

class Person(model):
    ...
    name = models.CharField()

class Membership(model):
    ...
    status = models.CharField()
    created_date = models.DateTimeField()
    modified_date = models.DateTimeField()
    person = models.ForeignKey(
        'Person',
        related_name='memberships',
    )
    group = models.ForeignKey(
        'Group',
        related_name='memberships',
    )

在会员资格中,我有代表个人和乐队的字段,以及创建日期和更新日期,以及其他相关数据。

问题在于:成员资格行没有任何表示规范记录的字段,它们混合并匹配人员、日期和其他数据。

我目前正在做的是获取给定乐队的所有会员资格,运行 对乐队和个人的组合进行区分,并使用这些结果再次查询会员资格以获得最新的实例每个特定的组合。虽然这可行,但正如您想象的那样,速度慢得无法形容,我知道一定有更好的方法。

所以我正在寻找如何使用一些高级的 django 查询表达式(Window?完了,F 表达式?)来尽可能多地在数据库上完成这项工作。

这是获取我想要的记录的代码:

groups = (the groups I want)
for group in groups:
    unique_members = group.members.values(
        'person',
        'group',
    ).distinct()
    for member in members:
        current_member = group.members.filter(
            person__id=member['person'],
            group__id=member['structure'],
        ).lastest('created_date', 'modified_date')

current_member 是该唯一 person/group 组合的最新会员条目。

所以对于这样的会员列表:

Person           Group        Created     Status
John Lennon      Beatles      1960-01-01  Current
Paul McCartney   Beatles      1960-01-01  Current
Pete Best        Beatles      1960-01-01  Expired
George Harrison  Beatles      1960-01-01  Current
Ringo Starr      Beatles      1962-01-01  Expired
Pete Best        Beatles      1964-01-01  Expired
Ringo Starr      Beatles      1966-01-01  Current

我想要以下列表:

John Lennon      Beatles      1960-01-01  Current
Paul McCartney   Beatles      1960-01-01  Current
Pete Best        Beatles      1964-01-01  Expired
George Harrison  Beatles      1960-01-01  Current
Ringo Starr      Beatles      1966-01-01  Current

从单个查询生成。

谢谢!

您可以先按所需条目对会员查询进行排序,然后获取不同的值。这个问题可能对你有帮助:

Django query: get the last entries of all distinct values by list