如何通过Django中的表在manytomany中添加自定义字段

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

我有一个模型与另一个模型有很多关系。这将创建一个隐藏直通表,其中包含前两个表的两个外键字段。现在我想在直通表中除了现有的两个外键字段之外添加自定义字段。

型号一:

class ModelOne(models.Model):
    field_one = models.CharField(max_length=264)

型号二:

class ModelTwo(models.Model):
    many_field = models.ManyToManyField(ModelOne, related_name='some_name')
    field_one = models.CharField(max_length=264)

通过表格自动创建隐藏:

class appname_modeltwo_modelone(models.Model):
    model_one_id= models.ForeignKey(ModelOne)
    model_two_id= models.ForeignKey(ModelTwo)
    custom_field= models.CharField(max_length=264) # New Custom Field I want to add

如何在此处添加新的自定义字段?

django django-models manytomanyfield
2个回答
11
投票

您可以使用 through 参数在多对多关系上添加额外的字段,以指向将充当中介的模型,根据 django doc

在你的例子中

class ModelOne(models.Model):
    field_one = models.CharField(max_length=264)

class ModelTwo(models.Model):
    many_field = models.ManyToManyField(ModelOne, related_name='some_name', through='IntermediateModel')
    field_one = models.CharField(max_length=264)

class IntermediateModel(models.Model):
    model_one = models.ForeignKey(ModelOne, on_delete=models.CASCADE)
    model_two = models.ForeignKey(ModelTwo, on_delete=models.CASCADE)
    custom_field = models.DateField()
    custom_field_2 = models.CharField(max_length=64)

0
投票

但是使用上述解决方案现有数据会丢失任何其他解决方案吗?

© www.soinside.com 2019 - 2024. All rights reserved.