首页 > 解决方案 > Django 多对多

问题描述

我对 django 相当陌生,我正在尝试使用以下模型创建一个应用程序

class User(models.Model):
    name = models.CharField(max_length=20)


class Group(models.Model):
    identifier = models.CharField(max_length=3,primary_key=True)
    name = models.CharField(max_length=120)
    def __str__(self):
        return self.name
class Department(models.Model):
    users = models.ManyToManyField(User)
    ric = models.CharField(max_length=12,primary_key=True)
    name = models.CharField(max_length=60)
    def __str__(self):
        return self.name

class Encounter(models.Model):
    department = models.ForeignKey(Department,on_delete=models.DO_NOTHING)
    message = models.CharField(max_length=120)
    datetime = models.DateTimeField()

用户最终将成为登录用户。我能够为用户获取一组所有部门对象,但是如何获取具有所述部门集合的所有遭遇的集合?是否有一些内置方式,或者我只是在所有部门上使用 for 循环?

标签: pythondjangodjango-models

解决方案


可能的方法之一:

encounters = Encounter.objects.filter(
    department__in=QUERYSET_CONTAINING_DEPARTMENTS,
).distinct()

您可能想阅读:多对一关系


推荐阅读