models.py 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. """
  2. Tests for the update() queryset method that allows in-place, multi-object
  3. updates.
  4. """
  5. from django.db import models
  6. class DataPoint(models.Model):
  7. name = models.CharField(max_length=20)
  8. value = models.CharField(max_length=20)
  9. another_value = models.CharField(max_length=20, blank=True)
  10. is_active = models.BooleanField(default=True)
  11. class RelatedPoint(models.Model):
  12. name = models.CharField(max_length=20)
  13. data = models.ForeignKey(DataPoint, models.CASCADE)
  14. class A(models.Model):
  15. x = models.IntegerField(default=10)
  16. class B(models.Model):
  17. a = models.ForeignKey(A, models.CASCADE)
  18. y = models.IntegerField(default=10)
  19. class C(models.Model):
  20. y = models.IntegerField(default=10)
  21. class D(C):
  22. a = models.ForeignKey(A, models.CASCADE)
  23. class Foo(models.Model):
  24. target = models.CharField(max_length=10, unique=True)
  25. class Bar(models.Model):
  26. foo = models.ForeignKey(Foo, models.CASCADE, to_field="target")
  27. m2m_foo = models.ManyToManyField(Foo, related_name="m2m_foo")
  28. x = models.IntegerField(default=0)
  29. class UniqueNumber(models.Model):
  30. number = models.IntegerField(unique=True)
  31. class UniqueNumberChild(UniqueNumber):
  32. pass