Подтвердить что ты не робот

Django ManyToMany Связь с дополнительными полями

Я хочу сохранить некоторую дополнительную информацию в этом, автоматически созданном, ManyToMany join-table. Как мне это сделать в Django?

В моем случае у меня есть две таблицы: "Сотрудники" и "Проекты". Я хочу хранить то, сколько каждый сотрудник получает за час работы в каждом из проектов, поскольку эти значения не совпадают. Итак, как бы я это сделал?

Что мне пришло в голову, вместо метода "ManyToManyField" создать явно третий класс/таблицу для хранения этих новых сведений и установить его связь с "Сотрудниками" и "Проектами" с использованием метода "ForeignKey". Я уверен, что это сработает, но лучший ли это подход?

4b9b3361

Ответ 1

Вот пример того, чего вы хотите достичь:

http://docs.djangoproject.com/en/dev/topics/db/models/#extra-fields-on-many-to-many-relationships

В случае разрыва ссылки:

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)