123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345 |
- """
- Various complex queries that have been problematic in the past.
- """
- import threading
- from django.db import models
- class DumbCategory(models.Model):
- pass
- class NamedCategory(DumbCategory):
- name = models.CharField(max_length=10)
- class Tag(models.Model):
- name = models.CharField(max_length=10)
- parent = models.ForeignKey('self', blank=True, null=True,
- related_name='children')
- category = models.ForeignKey(NamedCategory, null=True, default=None)
- class Meta:
- ordering = ['name']
- def __unicode__(self):
- return self.name
- class Note(models.Model):
- note = models.CharField(max_length=100)
- misc = models.CharField(max_length=10)
- class Meta:
- ordering = ['note']
- def __unicode__(self):
- return self.note
- def __init__(self, *args, **kwargs):
- super(Note, self).__init__(*args, **kwargs)
-
-
-
- self.lock = threading.Lock()
- class Annotation(models.Model):
- name = models.CharField(max_length=10)
- tag = models.ForeignKey(Tag)
- notes = models.ManyToManyField(Note)
- def __unicode__(self):
- return self.name
- class ExtraInfo(models.Model):
- info = models.CharField(max_length=100)
- note = models.ForeignKey(Note)
- class Meta:
- ordering = ['info']
- def __unicode__(self):
- return self.info
- class Author(models.Model):
- name = models.CharField(max_length=10)
- num = models.IntegerField(unique=True)
- extra = models.ForeignKey(ExtraInfo)
- class Meta:
- ordering = ['name']
- def __unicode__(self):
- return self.name
- class Item(models.Model):
- name = models.CharField(max_length=10)
- created = models.DateTimeField()
- modified = models.DateTimeField(blank=True, null=True)
- tags = models.ManyToManyField(Tag, blank=True, null=True)
- creator = models.ForeignKey(Author)
- note = models.ForeignKey(Note)
- class Meta:
- ordering = ['-note', 'name']
- def __unicode__(self):
- return self.name
- class Report(models.Model):
- name = models.CharField(max_length=10)
- creator = models.ForeignKey(Author, to_field='num', null=True)
- def __unicode__(self):
- return self.name
- class Ranking(models.Model):
- rank = models.IntegerField()
- author = models.ForeignKey(Author)
- class Meta:
-
- ordering = ('author__extra__note', 'author__name', 'rank')
- def __unicode__(self):
- return '%d: %s' % (self.rank, self.author.name)
- class Cover(models.Model):
- title = models.CharField(max_length=50)
- item = models.ForeignKey(Item)
- class Meta:
- ordering = ['item']
- def __unicode__(self):
- return self.title
- class Number(models.Model):
- num = models.IntegerField()
- def __unicode__(self):
- return unicode(self.num)
- class Valid(models.Model):
- valid = models.CharField(max_length=10)
- parent = models.ManyToManyField('self')
- class Meta:
- ordering = ['valid']
- class X(models.Model):
- y = models.ForeignKey('Y')
- class Y(models.Model):
- x1 = models.ForeignKey(X, related_name='y1')
- class LoopX(models.Model):
- y = models.ForeignKey('LoopY')
- class Meta:
- ordering = ['y']
- class LoopY(models.Model):
- x = models.ForeignKey(LoopX)
- class Meta:
- ordering = ['x']
- class LoopZ(models.Model):
- z = models.ForeignKey('self')
- class Meta:
- ordering = ['z']
- class CustomManager(models.Manager):
- def get_query_set(self):
- qs = super(CustomManager, self).get_query_set()
- return qs.filter(public=True, tag__name='t1')
- class ManagedModel(models.Model):
- data = models.CharField(max_length=10)
- tag = models.ForeignKey(Tag)
- public = models.BooleanField(default=True)
- objects = CustomManager()
- normal_manager = models.Manager()
- def __unicode__(self):
- return self.data
- class Detail(models.Model):
- data = models.CharField(max_length=10)
- class MemberManager(models.Manager):
- def get_query_set(self):
- return super(MemberManager, self).get_query_set().select_related("details")
- class Member(models.Model):
- name = models.CharField(max_length=10)
- details = models.OneToOneField(Detail, primary_key=True)
- objects = MemberManager()
- class Child(models.Model):
- person = models.OneToOneField(Member, primary_key=True)
- parent = models.ForeignKey(Member, related_name="children")
- class CustomPk(models.Model):
- name = models.CharField(max_length=10, primary_key=True)
- extra = models.CharField(max_length=10)
- class Meta:
- ordering = ['name', 'extra']
- class Related(models.Model):
- custom = models.ForeignKey(CustomPk)
- class Celebrity(models.Model):
- name = models.CharField("Name", max_length=20)
- greatest_fan = models.ForeignKey("Fan", null=True, unique=True)
- class TvChef(Celebrity):
- pass
- class Fan(models.Model):
- fan_of = models.ForeignKey(Celebrity)
- class LeafA(models.Model):
- data = models.CharField(max_length=10)
- def __unicode__(self):
- return self.data
- class LeafB(models.Model):
- data = models.CharField(max_length=10)
- class Join(models.Model):
- a = models.ForeignKey(LeafA)
- b = models.ForeignKey(LeafB)
- class ReservedName(models.Model):
- name = models.CharField(max_length=20)
- order = models.IntegerField()
- def __unicode__(self):
- return self.name
- class SharedConnection(models.Model):
- data = models.CharField(max_length=10)
- class PointerA(models.Model):
- connection = models.ForeignKey(SharedConnection)
- class PointerB(models.Model):
- connection = models.ForeignKey(SharedConnection)
- class SingleObject(models.Model):
- name = models.CharField(max_length=10)
- class Meta:
- ordering = ['name']
- def __unicode__(self):
- return self.name
- class RelatedObject(models.Model):
- single = models.ForeignKey(SingleObject)
- class Meta:
- ordering = ['single']
- class Plaything(models.Model):
- name = models.CharField(max_length=10)
- others = models.ForeignKey(RelatedObject, null=True)
- class Meta:
- ordering = ['others']
- def __unicode__(self):
- return self.name
- class Article(models.Model):
- name = models.CharField(max_length=20)
- created = models.DateTimeField()
- class Food(models.Model):
- name = models.CharField(max_length=20, unique=True)
- def __unicode__(self):
- return self.name
- class Eaten(models.Model):
- food = models.ForeignKey(Food, to_field="name")
- meal = models.CharField(max_length=20)
- def __unicode__(self):
- return u"%s at %s" % (self.food, self.meal)
- class Node(models.Model):
- num = models.IntegerField(unique=True)
- parent = models.ForeignKey("self", to_field="num", null=True)
- def __unicode__(self):
- return u"%s" % self.num
- class ObjectA(models.Model):
- name = models.CharField(max_length=50)
- def __unicode__(self):
- return self.name
- class ObjectB(models.Model):
- name = models.CharField(max_length=50)
- objecta = models.ForeignKey(ObjectA)
- num = models.PositiveSmallIntegerField()
- def __unicode__(self):
- return self.name
- class ObjectC(models.Model):
- name = models.CharField(max_length=50)
- objecta = models.ForeignKey(ObjectA)
- objectb = models.ForeignKey(ObjectB)
- def __unicode__(self):
- return self.name
- class SimpleCategory(models.Model):
- name = models.CharField(max_length=15)
- def __unicode__(self):
- return self.name
- class SpecialCategory(SimpleCategory):
- special_name = models.CharField(max_length=15)
- def __unicode__(self):
- return self.name + " " + self.special_name
- class CategoryItem(models.Model):
- category = models.ForeignKey(SimpleCategory)
- def __unicode__(self):
- return "category item: " + str(self.category)
- class OneToOneCategory(models.Model):
- new_name = models.CharField(max_length=15)
- category = models.OneToOneField(SimpleCategory)
- def __unicode__(self):
- return "one2one " + self.new_name
-
|