Многоязыковая связь Джанго с дополнительными полями - PullRequest
58 голосов
/ 14 декабря 2010

Я хочу сохранить некоторую дополнительную информацию в автоматически создаваемой объединенной таблице ManyToMany. Как бы я сделал это в Джанго?

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

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

1 Ответ

85 голосов
/ 14 декабря 2010

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

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)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...