models.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. from django.contrib.contenttypes import generic
  2. from django.contrib.contenttypes.models import ContentType
  3. from django.db import models
  4. from django.db import connection
  5. class Square(models.Model):
  6. root = models.IntegerField()
  7. square = models.PositiveIntegerField()
  8. def __unicode__(self):
  9. return "%s ** 2 == %s" % (self.root, self.square)
  10. class Person(models.Model):
  11. first_name = models.CharField(max_length=20)
  12. last_name = models.CharField(max_length=20)
  13. def __unicode__(self):
  14. return u'%s %s' % (self.first_name, self.last_name)
  15. class SchoolClass(models.Model):
  16. year = models.PositiveIntegerField()
  17. day = models.CharField(max_length=9, blank=True)
  18. last_updated = models.DateTimeField()
  19. # Unfortunately, the following model breaks MySQL hard.
  20. # Until #13711 is fixed, this test can't be run under MySQL.
  21. if connection.features.supports_long_model_names:
  22. class VeryLongModelNameZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ(models.Model):
  23. class Meta:
  24. # We need to use a short actual table name or
  25. # we hit issue #8548 which we're not testing!
  26. verbose_name = 'model_with_long_table_name'
  27. primary_key_is_quite_long_zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz = models.AutoField(primary_key=True)
  28. charfield_is_quite_long_zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz = models.CharField(max_length=100)
  29. m2m_also_quite_long_zzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzzz = models.ManyToManyField(Person,blank=True)
  30. class Tag(models.Model):
  31. name = models.CharField(max_length=30)
  32. content_type = models.ForeignKey(ContentType, related_name='backend_tags')
  33. object_id = models.PositiveIntegerField()
  34. content_object = generic.GenericForeignKey('content_type', 'object_id')
  35. class Post(models.Model):
  36. name = models.CharField(max_length=30)
  37. text = models.TextField()
  38. tags = generic.GenericRelation('Tag')
  39. class Meta:
  40. db_table = 'CaseSensitive_Post'
  41. class Reporter(models.Model):
  42. first_name = models.CharField(max_length=30)
  43. last_name = models.CharField(max_length=30)
  44. def __unicode__(self):
  45. return u"%s %s" % (self.first_name, self.last_name)
  46. class Article(models.Model):
  47. headline = models.CharField(max_length=100)
  48. pub_date = models.DateField()
  49. reporter = models.ForeignKey(Reporter)
  50. def __unicode__(self):
  51. return self.headline