2006-05-02 03:31:56 +02:00
|
|
|
"""
|
|
|
|
9. Many-to-many relationships via an intermediary table
|
|
|
|
|
|
|
|
For many-to-many relationships that need extra fields on the intermediary
|
|
|
|
table, use an intermediary model.
|
|
|
|
|
2008-08-12 16:15:38 +02:00
|
|
|
In this example, an ``Article`` can have multiple ``Reporter`` objects, and
|
|
|
|
each ``Article``-``Reporter`` combination (a ``Writer``) has a ``position``
|
|
|
|
field, which specifies the ``Reporter``'s position for the given article
|
|
|
|
(e.g. "Staff writer").
|
2006-05-02 03:31:56 +02:00
|
|
|
"""
|
2012-06-07 18:08:47 +02:00
|
|
|
from __future__ import unicode_literals
|
2006-05-02 03:31:56 +02:00
|
|
|
|
|
|
|
from django.db import models
|
2012-08-12 12:32:08 +02:00
|
|
|
from django.utils.encoding import python_2_unicode_compatible
|
2006-05-02 03:31:56 +02:00
|
|
|
|
2011-10-13 20:04:12 +02:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2006-05-02 03:31:56 +02:00
|
|
|
class Reporter(models.Model):
|
2007-08-05 07:14:46 +02:00
|
|
|
first_name = models.CharField(max_length=30)
|
|
|
|
last_name = models.CharField(max_length=30)
|
2006-05-02 03:31:56 +02:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2012-06-07 18:08:47 +02:00
|
|
|
return "%s %s" % (self.first_name, self.last_name)
|
2006-05-02 03:31:56 +02:00
|
|
|
|
2013-11-03 05:36:09 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2006-05-02 03:31:56 +02:00
|
|
|
class Article(models.Model):
|
2007-08-05 07:14:46 +02:00
|
|
|
headline = models.CharField(max_length=100)
|
2006-05-02 03:31:56 +02:00
|
|
|
pub_date = models.DateField()
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2006-05-02 03:31:56 +02:00
|
|
|
return self.headline
|
|
|
|
|
2013-11-03 05:36:09 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2006-05-02 03:31:56 +02:00
|
|
|
class Writer(models.Model):
|
|
|
|
reporter = models.ForeignKey(Reporter)
|
|
|
|
article = models.ForeignKey(Article)
|
2007-08-05 07:14:46 +02:00
|
|
|
position = models.CharField(max_length=100)
|
2006-05-02 03:31:56 +02:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2012-06-07 18:08:47 +02:00
|
|
|
return '%s (%s)' % (self.reporter, self.position)
|