2007-02-28 23:24:05 +08:00
|
|
|
"""
|
2014-09-24 13:13:13 +08:00
|
|
|
Tests for select_related()
|
2007-02-28 23:24:05 +08:00
|
|
|
|
|
|
|
``select_related()`` follows all relationships and pre-caches any foreign key
|
|
|
|
values so that complex trees can be fetched in a single query. However, this
|
|
|
|
isn't always a good idea, so the ``depth`` argument control how many "levels"
|
|
|
|
the select-related behavior will traverse.
|
|
|
|
"""
|
|
|
|
|
2015-01-28 20:35:27 +08:00
|
|
|
from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
|
|
|
|
from django.contrib.contenttypes.models import ContentType
|
2007-02-28 23:24:05 +08:00
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
# Who remembers high school biology?
|
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Domain(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Kingdom(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
domain = models.ForeignKey(Domain, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Phylum(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
kingdom = models.ForeignKey(Kingdom, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Klass(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
phylum = models.ForeignKey(Phylum, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Order(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
klass = models.ForeignKey(Klass, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Family(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
order = models.ForeignKey(Order, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Genus(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
family = models.ForeignKey(Family, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2013-11-03 05:34:05 +08:00
|
|
|
|
2007-02-28 23:24:05 +08:00
|
|
|
class Species(models.Model):
|
2007-08-05 13:14:46 +08:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
genus = models.ForeignKey(Genus, models.CASCADE)
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2022-02-04 03:24:19 +08:00
|
|
|
|
2013-10-15 20:15:02 +08:00
|
|
|
# and we'll invent a new thing so we have a model with two foreign keys
|
2013-11-03 05:34:05 +08:00
|
|
|
|
|
|
|
|
2013-10-15 20:15:02 +08:00
|
|
|
class HybridSpecies(models.Model):
|
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 22:43:21 +08:00
|
|
|
parent_1 = models.ForeignKey(Species, models.CASCADE, related_name="child_1")
|
|
|
|
parent_2 = models.ForeignKey(Species, models.CASCADE, related_name="child_2")
|
2013-10-22 18:21:07 +08:00
|
|
|
|
2014-12-05 04:47:48 +08:00
|
|
|
|
|
|
|
class Topping(models.Model):
|
|
|
|
name = models.CharField(max_length=30)
|
|
|
|
|
|
|
|
|
|
|
|
class Pizza(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
toppings = models.ManyToManyField(Topping)
|
|
|
|
|
|
|
|
|
|
|
|
class TaggedItem(models.Model):
|
|
|
|
tag = models.CharField(max_length=30)
|
|
|
|
|
2015-07-22 22:43:21 +08:00
|
|
|
content_type = models.ForeignKey(
|
|
|
|
ContentType, models.CASCADE, related_name="select_related_tagged_items"
|
|
|
|
)
|
2014-12-05 04:47:48 +08:00
|
|
|
object_id = models.PositiveIntegerField()
|
|
|
|
content_object = GenericForeignKey("content_type", "object_id")
|
|
|
|
|
|
|
|
|
|
|
|
class Bookmark(models.Model):
|
|
|
|
url = models.URLField()
|
|
|
|
tags = GenericRelation(TaggedItem)
|