2

我有一个 Django 应用程序,其中包含三个模型,这些模型使用 ContentTypes 和 Generic 来尝试并允许 Task 模型使用如何在 Django 中使用动态外键来对其他两个模型中的任何一个具有 ForeignKey?作为指南(尽管我承认我不知道这种方法发生了什么)。

class Task(models.Model):
    date = models.DateTimeField(null = True)
    day = models.IntegerField(null = True)
    task = models.CharField(max_length = 100, null = False)
    owner = models.CharField(max_length = 25, null = True)
    notes = models.CharField(max_length = 250, null = True)
    isDone = models.BooleanField(default = False, null = False)

    content_type = models.ForeignKey(ContentType)
    object_id = models.PositiveIntegerField()
    maintenance = generic.GenericForeignKey('content_type', 'object_id')

class Maintenance(models.Model):
    startMonth = models.CharField(max_length = 15, null = False)
    startYear = models.IntegerField(null = False)
    location = models.CharField(max_length = 20, null = False)
    mode = models.CharField(max_length = 20, null = False)

    taskRef = generic.GenericRelation(Task)

class Template(models.Model):
    name = models.CharField(max_length = 25, null = False)
    location = models.CharField(max_length = 20, null = False)
    mode = models.CharField(max_length = 20, null = False)

    taskRef = generic.GenericRelation(Task)

通常,如果任务只有一个正常的外键来维护,我可以使用 Maintenance.task_set.all() 将所有任务连接到任何给定的维护,但是使用这个动态外键系统,该功能不起作用。有谁知道实现这种效果的替代函数调用?

4

1 回答 1

1

就像user710907 所说,Maintenance.taskRef.all() 应该可以解决问题。当您指定 ForeignKey 关系时,您可以设置用于反向关系的“related_name”参数。如果您不指定,则默认为“model_name_set”。

class Foo(models.Model):
    ...

class Bar(models.Model):
    ...
    foo = models.ForeignKey(Foo, related_name="related_bars")

现在,您可以bar.foo从一侧或另一侧访问该关系foo.related_bars。如果您不指定,后一个参数将默认为foo.bar_set.

在您的示例中,您从双方定义关系;FK 在 Task 上定义,reference 在 Maintenance 和 Template 上定义。由于您在处理关系的两个模型上都提供了字段,因此无需提供 maintenance_set 默认值。

编辑:经过进一步检查,我认为部分混乱可能与您的Task.maintenance领域有关。如果我没记错的话,那是您要指向的字段Maintenance Template,对吗?那为什么叫它maintenance呢?我绝对建议您也阅读文档的这一部分

于 2013-07-18T14:34:07.553 回答