Django与其他字段的ManyToMany关系

我想在其中自动创建的ManyToMany联接表中存储一些其他信息。我将如何在Django中做到这一点?

就我而言,我有两个表:“雇员”和“项目”。我要存储的是每个项目中每个员工每小时工作所获得的收入,因为这些价值并不相同。那么,我该怎么做呢?

我想到的是,不是使用方法“ ManyToManyField”,而是显式创建了一个第三类/表来存储这些新信息,并使用“ ForeignKey”方法设置其与“ Employees”和“ Projects”的关系。我很确定它会起作用,但这是最好的方法吗?

回答:

万一链接中断:

from django.db import models

class Person(models.Model):

name = models.CharField(max_length=128)

def __str__(self): # __unicode__ on Python 2

return self.name

class Group(models.Model):

name = models.CharField(max_length=128)

members = models.ManyToManyField(Person, through='Membership')

def __str__(self): # __unicode__ on Python 2

return self.name

class Membership(models.Model):

person = models.ForeignKey(Person)

group = models.ForeignKey(Group)

date_joined = models.DateField()

invite_reason = models.CharField(max_length=64)

以上是 Django与其他字段的ManyToMany关系 的全部内容, 来源链接: utcz.com/qa/403074.html

回到顶部