2006-05-02 09:31:56 +08:00
|
|
|
"""
|
2014-09-24 13:13:13 +08:00
|
|
|
Many-to-one relationships
|
2006-05-02 09:31:56 +08:00
|
|
|
|
2008-08-12 22:15:38 +08:00
|
|
|
To define a many-to-one relationship, use ``ForeignKey()``.
|
2006-05-02 09:31:56 +08:00
|
|
|
"""
|
|
|
|
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
|
|
|
first_name = models.CharField(max_length=30)
|
|
|
|
last_name = models.CharField(max_length=30)
|
2006-05-02 09:31:56 +08:00
|
|
|
email = models.EmailField()
|
|
|
|
|
2012-08-12 18:32:08 +08:00
|
|
|
def __str__(self):
|
2012-06-08 00:08:47 +08:00
|
|
|
return "%s %s" % (self.first_name, self.last_name)
|
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)
|
2006-05-02 09:31:56 +08:00
|
|
|
pub_date = models.DateField()
|
2015-07-22 22:43:21 +08:00
|
|
|
reporter = models.ForeignKey(Reporter, models.CASCADE)
|
2006-05-02 09:31:56 +08:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
ordering = ("headline",)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
2018-12-28 08:34:14 +08:00
|
|
|
def __str__(self):
|
|
|
|
return self.headline
|
|
|
|
|
2014-09-24 00:29:17 +08:00
|
|
|
|
2019-07-27 05:05:22 +08:00
|
|
|
class Country(models.Model):
|
|
|
|
id = models.SmallAutoField(primary_key=True)
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
|
|
|
|
|
2015-07-02 16:43:15 +08:00
|
|
|
class City(models.Model):
|
|
|
|
id = models.BigAutoField(primary_key=True)
|
2019-07-27 05:05:22 +08:00
|
|
|
country = models.ForeignKey(
|
|
|
|
Country, models.CASCADE, related_name="cities", null=True
|
|
|
|
)
|
2015-07-02 16:43:15 +08:00
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
|
|
|
|
|
|
|
|
class District(models.Model):
|
2016-06-05 20:15:00 +08:00
|
|
|
city = models.ForeignKey(City, models.CASCADE, related_name="districts", null=True)
|
2015-07-02 16:43:15 +08:00
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
2014-09-24 00:29:17 +08:00
|
|
|
# If ticket #1578 ever slips back in, these models will not be able to be
|
2018-09-25 22:30:18 +08:00
|
|
|
# created (the field names being lowercased versions of their opposite classes
|
|
|
|
# is important here).
|
2014-09-24 00:29:17 +08:00
|
|
|
class First(models.Model):
|
|
|
|
second = models.IntegerField()
|
|
|
|
|
|
|
|
|
|
|
|
class Second(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
first = models.ForeignKey(First, models.CASCADE, related_name="the_first")
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
# Protect against repetition of #1839, #2415 and #2536.
|
|
|
|
class Third(models.Model):
|
|
|
|
name = models.CharField(max_length=20)
|
2015-07-22 22:43:21 +08:00
|
|
|
third = models.ForeignKey(
|
|
|
|
"self", models.SET_NULL, null=True, related_name="child_set"
|
|
|
|
)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Parent(models.Model):
|
|
|
|
name = models.CharField(max_length=20, unique=True)
|
2015-07-22 22:43:21 +08:00
|
|
|
bestchild = models.ForeignKey(
|
|
|
|
"Child", models.SET_NULL, null=True, related_name="favored_by"
|
|
|
|
)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
2021-02-03 00:58:04 +08:00
|
|
|
class ParentStringPrimaryKey(models.Model):
|
|
|
|
name = models.CharField(primary_key=True, max_length=15)
|
|
|
|
|
|
|
|
|
2014-09-24 00:29:17 +08:00
|
|
|
class Child(models.Model):
|
|
|
|
name = models.CharField(max_length=20)
|
2015-07-22 22:43:21 +08:00
|
|
|
parent = models.ForeignKey(Parent, models.CASCADE)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
2019-05-20 20:06:30 +08:00
|
|
|
class ChildNullableParent(models.Model):
|
|
|
|
parent = models.ForeignKey(Parent, models.CASCADE, null=True)
|
|
|
|
|
|
|
|
|
2021-02-03 00:58:04 +08:00
|
|
|
class ChildStringPrimaryKeyParent(models.Model):
|
|
|
|
parent = models.ForeignKey(ParentStringPrimaryKey, on_delete=models.CASCADE)
|
|
|
|
|
|
|
|
|
2014-09-24 00:29:17 +08:00
|
|
|
class ToFieldChild(models.Model):
|
2018-11-01 13:10:29 +08:00
|
|
|
parent = models.ForeignKey(
|
|
|
|
Parent, models.CASCADE, to_field="name", related_name="to_field_children"
|
|
|
|
)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
# Multiple paths to the same model (#7110, #7125)
|
|
|
|
class Category(models.Model):
|
|
|
|
name = models.CharField(max_length=20)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
|
|
|
class Record(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
category = models.ForeignKey(Category, models.CASCADE)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Relation(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
left = models.ForeignKey(Record, models.CASCADE, related_name="left_set")
|
|
|
|
right = models.ForeignKey(Record, models.CASCADE, related_name="right_set")
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return "%s - %s" % (self.left.category.name, self.right.category.name)
|
|
|
|
|
|
|
|
|
|
|
|
# Test related objects visibility.
|
|
|
|
class SchoolManager(models.Manager):
|
|
|
|
def get_queryset(self):
|
2017-01-21 21:13:44 +08:00
|
|
|
return super().get_queryset().filter(is_public=True)
|
2014-09-24 00:29:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
class School(models.Model):
|
|
|
|
is_public = models.BooleanField(default=False)
|
|
|
|
objects = SchoolManager()
|
|
|
|
|
|
|
|
|
|
|
|
class Student(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
school = models.ForeignKey(School, models.CASCADE)
|