1. from django.db import models
    
  2. 
    
  3. 
    
  4. class Person(models.Model):
    
  5.     first_name = models.CharField(max_length=100, unique=True)
    
  6.     last_name = models.CharField(max_length=100)
    
  7.     birthday = models.DateField()
    
  8.     defaults = models.TextField()
    
  9. 
    
  10. 
    
  11. class DefaultPerson(models.Model):
    
  12.     first_name = models.CharField(max_length=100, default="Anonymous")
    
  13. 
    
  14. 
    
  15. class ManualPrimaryKeyTest(models.Model):
    
  16.     id = models.IntegerField(primary_key=True)
    
  17.     data = models.CharField(max_length=100)
    
  18. 
    
  19. 
    
  20. class Profile(models.Model):
    
  21.     person = models.ForeignKey(Person, models.CASCADE, primary_key=True)
    
  22. 
    
  23. 
    
  24. class Tag(models.Model):
    
  25.     text = models.CharField(max_length=255, unique=True)
    
  26. 
    
  27. 
    
  28. class Thing(models.Model):
    
  29.     name = models.CharField(max_length=255)
    
  30.     tags = models.ManyToManyField(Tag)
    
  31. 
    
  32.     @property
    
  33.     def capitalized_name_property(self):
    
  34.         return self.name
    
  35. 
    
  36.     @capitalized_name_property.setter
    
  37.     def capitalized_name_property(self, val):
    
  38.         self.name = val.capitalize()
    
  39. 
    
  40.     @property
    
  41.     def name_in_all_caps(self):
    
  42.         return self.name.upper()
    
  43. 
    
  44. 
    
  45. class Publisher(models.Model):
    
  46.     name = models.CharField(max_length=100)
    
  47. 
    
  48. 
    
  49. class Author(models.Model):
    
  50.     name = models.CharField(max_length=100)
    
  51. 
    
  52. 
    
  53. class Book(models.Model):
    
  54.     name = models.CharField(max_length=100)
    
  55.     authors = models.ManyToManyField(Author, related_name="books")
    
  56.     publisher = models.ForeignKey(
    
  57.         Publisher,
    
  58.         models.CASCADE,
    
  59.         related_name="books",
    
  60.         db_column="publisher_id_column",
    
  61.     )