models.py 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. from django.contrib.auth.models import User
  2. from django.db import models
  3. # Forward declared intermediate model
  4. class Membership(models.Model):
  5. person = models.ForeignKey('Person', models.CASCADE)
  6. group = models.ForeignKey('Group', models.CASCADE)
  7. price = models.IntegerField(default=100)
  8. # using custom id column to test ticket #11107
  9. class UserMembership(models.Model):
  10. id = models.AutoField(db_column='usermembership_id', primary_key=True)
  11. user = models.ForeignKey(User, models.CASCADE)
  12. group = models.ForeignKey('Group', models.CASCADE)
  13. price = models.IntegerField(default=100)
  14. class Person(models.Model):
  15. name = models.CharField(max_length=128)
  16. def __str__(self):
  17. return self.name
  18. class Group(models.Model):
  19. name = models.CharField(max_length=128)
  20. # Membership object defined as a class
  21. members = models.ManyToManyField(Person, through=Membership)
  22. user_members = models.ManyToManyField(User, through='UserMembership')
  23. def __str__(self):
  24. return self.name
  25. # Using to_field on the through model
  26. class Car(models.Model):
  27. make = models.CharField(max_length=20, unique=True, null=True)
  28. drivers = models.ManyToManyField('Driver', through='CarDriver')
  29. def __str__(self):
  30. return str(self.make)
  31. class Driver(models.Model):
  32. name = models.CharField(max_length=20, unique=True, null=True)
  33. class Meta:
  34. ordering = ('name',)
  35. def __str__(self):
  36. return str(self.name)
  37. class CarDriver(models.Model):
  38. car = models.ForeignKey('Car', models.CASCADE, to_field='make')
  39. driver = models.ForeignKey('Driver', models.CASCADE, to_field='name')
  40. def __str__(self):
  41. return "pk=%s car=%s driver=%s" % (str(self.pk), self.car, self.driver)
  42. # Through models using multi-table inheritance
  43. class Event(models.Model):
  44. name = models.CharField(max_length=50, unique=True)
  45. people = models.ManyToManyField('Person', through='IndividualCompetitor')
  46. special_people = models.ManyToManyField(
  47. 'Person',
  48. through='ProxiedIndividualCompetitor',
  49. related_name='special_event_set',
  50. )
  51. teams = models.ManyToManyField('Group', through='CompetingTeam')
  52. class Competitor(models.Model):
  53. event = models.ForeignKey(Event, models.CASCADE)
  54. class IndividualCompetitor(Competitor):
  55. person = models.ForeignKey(Person, models.CASCADE)
  56. class CompetingTeam(Competitor):
  57. team = models.ForeignKey(Group, models.CASCADE)
  58. class ProxiedIndividualCompetitor(IndividualCompetitor):
  59. class Meta:
  60. proxy = True