web-dev-qa-db-ja.com

DjangoのManyToManyと追加フィールドとの関係

自動的に作成されたManyToMany結合テーブルにいくつかの追加情報を保存したいと思います。 Djangoでそれを行うにはどうすればよいですか?

私の場合、「従業員」と「プロジェクト」の2つのテーブルがあります。私が保存したいのは、各プロジェクトの1時間あたりの各従業員が受け取る金額です。これらの値は同じではないからです。それで、どうすればそれができますか?

私に起こったのは、メソッド「ManyToManyField」の代わりに、これらの新しい情報を保存し、「ForeignKey」メソッドを使用して「Employees」および「Projects」との関係を設定するための3番目のクラス/テーブルを明示的に作成することでした私はそれがうまくいくと確信していますが、これが最良のアプローチですか?

58
Rodrogo

達成したい例を次に示します。

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)
87
gruszczy