2006-05-02 09:31:56 +08:00
|
|
|
"""
|
2014-09-24 13:13:13 +08:00
|
|
|
Many-to-one relationships that can be null
|
2006-05-02 09:31:56 +08:00
|
|
|
|
|
|
|
To define a many-to-one relationship that can have a null foreign key, use
|
|
|
|
``ForeignKey()`` with ``null=True`` .
|
|
|
|
"""
|
|
|
|
|
|
|
|
from django.db import models
|
|
|
|
|
2011-10-14 02:04:12 +08:00
|
|
|
|
2006-05-02 09:31:56 +08:00
|
|
|
class Reporter(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=30)
|
2006-05-02 09:31:56 +08:00
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2006-05-02 09:31:56 +08:00
|
|
|
class Article(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
headline = models.CharField(max_length=100)
|
2015-07-22 22:43:21 +08:00
|
|
|
reporter = models.ForeignKey(Reporter, models.SET_NULL, null=True)
|
2006-05-02 09:31:56 +08:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
ordering = ("headline",)
|
2006-06-04 08:23:51 +08:00
|
|
|
|
2012-08-12 18:32:08 +08:00
|
|
|
def __str__(self):
|
2006-06-04 08:23:51 +08:00
|
|
|
return self.headline
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Car(models.Model):
|
|
|
|
make = models.CharField(max_length=100, null=True, unique=True)
|
|
|
|
|
|
|
|
|
|
|
|
class Driver(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
car = models.ForeignKey(
|
|
|
|
Car, models.SET_NULL, to_field="make", null=True, related_name="drivers"
|
|
|
|
)
|