2007-02-28 15:24:05 +00:00
|
|
|
"""
|
2014-09-24 12:13:13 +07:00
|
|
|
Tests for select_related()
|
2007-02-28 15:24:05 +00: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 07:35:27 -05:00
|
|
|
from django.contrib.contenttypes.fields import (
|
|
|
|
GenericForeignKey, GenericRelation,
|
|
|
|
)
|
|
|
|
from django.contrib.contenttypes.models import ContentType
|
2007-02-28 15:24:05 +00:00
|
|
|
from django.db import models
|
2012-08-12 12:32:08 +02:00
|
|
|
from django.utils.encoding import python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
|
2014-12-04 21:47:48 +01:00
|
|
|
|
2007-02-28 15:24:05 +00:00
|
|
|
# Who remembers high school biology?
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Domain(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Kingdom(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
domain = models.ForeignKey(Domain, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Phylum(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
kingdom = models.ForeignKey(Kingdom, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 02:50:16 +00:00
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Klass(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
phylum = models.ForeignKey(Phylum, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
Merged the queryset-refactor branch into trunk.
This is a big internal change, but mostly backwards compatible with existing
code. Also adds a couple of new features.
Fixed #245, #1050, #1656, #1801, #2076, #2091, #2150, #2253, #2306, #2400, #2430, #2482, #2496, #2676, #2737, #2874, #2902, #2939, #3037, #3141, #3288, #3440, #3592, #3739, #4088, #4260, #4289, #4306, #4358, #4464, #4510, #4858, #5012, #5020, #5261, #5295, #5321, #5324, #5325, #5555, #5707, #5796, #5817, #5987, #6018, #6074, #6088, #6154, #6177, #6180, #6203, #6658
git-svn-id: http://code.djangoproject.com/svn/django/trunk@7477 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2008-04-27 02:50:16 +00:00
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Order(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
klass = models.ForeignKey(Klass, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Family(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
order = models.ForeignKey(Order, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Genus(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
family = models.ForeignKey(Family, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2007-02-28 15:24:05 +00:00
|
|
|
return self.name
|
|
|
|
|
2013-11-02 16:34:05 -05:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
@python_2_unicode_compatible
|
2007-02-28 15:24:05 +00:00
|
|
|
class Species(models.Model):
|
2007-08-05 05:14:46 +00:00
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05:00
|
|
|
genus = models.ForeignKey(Genus, models.CASCADE)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
2013-10-15 13:15:02 +01:00
|
|
|
|
|
|
|
# and we'll invent a new thing so we have a model with two foreign keys
|
2013-11-02 16:34:05 -05:00
|
|
|
|
|
|
|
|
2013-10-15 13:15:02 +01:00
|
|
|
@python_2_unicode_compatible
|
|
|
|
class HybridSpecies(models.Model):
|
|
|
|
name = models.CharField(max_length=50)
|
2015-07-22 09:43:21 -05: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 11:21:07 +01:00
|
|
|
|
2013-10-15 13:15:02 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
2014-12-04 21:47:48 +01:00
|
|
|
|
|
|
|
|
|
|
|
@python_2_unicode_compatible
|
|
|
|
class Topping(models.Model):
|
|
|
|
name = models.CharField(max_length=30)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
|
|
|
@python_2_unicode_compatible
|
|
|
|
class Pizza(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
toppings = models.ManyToManyField(Topping)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
|
|
|
@python_2_unicode_compatible
|
|
|
|
class TaggedItem(models.Model):
|
|
|
|
tag = models.CharField(max_length=30)
|
|
|
|
|
2015-07-22 09:43:21 -05:00
|
|
|
content_type = models.ForeignKey(ContentType, models.CASCADE, related_name='select_related_tagged_items')
|
2014-12-04 21:47:48 +01:00
|
|
|
object_id = models.PositiveIntegerField()
|
|
|
|
content_object = GenericForeignKey('content_type', 'object_id')
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.tag
|
|
|
|
|
|
|
|
|
|
|
|
@python_2_unicode_compatible
|
|
|
|
class Bookmark(models.Model):
|
|
|
|
url = models.URLField()
|
|
|
|
tags = GenericRelation(TaggedItem)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.url
|