2012-08-12 04:20:59 +08:00
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
2011-07-13 17:35:51 +08:00
|
|
|
from django.db import models
|
2012-08-12 18:32:08 +08:00
|
|
|
from django.utils.encoding import python_2_unicode_compatible
|
2008-06-22 04:55:17 +08:00
|
|
|
|
|
|
|
|
2012-08-12 18:32:08 +08:00
|
|
|
@python_2_unicode_compatible
|
2010-11-10 00:46:42 +08:00
|
|
|
class R(models.Model):
|
|
|
|
is_default = models.BooleanField(default=False)
|
2008-06-22 04:55:17 +08:00
|
|
|
|
2012-08-12 18:32:08 +08:00
|
|
|
def __str__(self):
|
2010-11-10 00:46:42 +08:00
|
|
|
return "%s" % self.pk
|
|
|
|
|
|
|
|
|
2015-07-16 09:18:07 +08:00
|
|
|
def get_default_r():
|
2015-07-16 20:00:29 +08:00
|
|
|
return R.objects.get_or_create(is_default=True)[0].pk
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
class S(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
r = models.ForeignKey(R, models.CASCADE)
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
class T(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
s = models.ForeignKey(S, models.CASCADE)
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
class U(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
t = models.ForeignKey(T, models.CASCADE)
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
class RChild(R):
|
2008-06-22 04:55:17 +08:00
|
|
|
pass
|
|
|
|
|
|
|
|
|
2010-11-10 00:46:42 +08:00
|
|
|
class A(models.Model):
|
|
|
|
name = models.CharField(max_length=30)
|
|
|
|
|
2015-07-22 22:43:21 +08:00
|
|
|
auto = models.ForeignKey(R, models.CASCADE, related_name="auto_set")
|
|
|
|
auto_nullable = models.ForeignKey(R, models.CASCADE, null=True,
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name='auto_nullable_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
setvalue = models.ForeignKey(R, models.SET(get_default_r),
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name='setvalue')
|
2015-07-22 22:43:21 +08:00
|
|
|
setnull = models.ForeignKey(R, models.SET_NULL, null=True,
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name='setnull_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
setdefault = models.ForeignKey(R, models.SET_DEFAULT,
|
2010-11-10 00:46:42 +08:00
|
|
|
default=get_default_r, related_name='setdefault_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
setdefault_none = models.ForeignKey(R, models.SET_DEFAULT,
|
2010-11-10 00:46:42 +08:00
|
|
|
default=None, null=True, related_name='setnull_nullable_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
cascade = models.ForeignKey(R, models.CASCADE,
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name='cascade_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
cascade_nullable = models.ForeignKey(R, models.CASCADE, null=True,
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name='cascade_nullable_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
protect = models.ForeignKey(R, models.PROTECT, null=True)
|
|
|
|
donothing = models.ForeignKey(R, models.DO_NOTHING, null=True,
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name='donothing_set')
|
2015-07-22 22:43:21 +08:00
|
|
|
child = models.ForeignKey(RChild, models.CASCADE, related_name="child")
|
|
|
|
child_setnull = models.ForeignKey(RChild, models.SET_NULL, null=True,
|
2010-11-10 00:46:42 +08:00
|
|
|
related_name="child_setnull")
|
|
|
|
|
|
|
|
# A OneToOneField is just a ForeignKey unique=True, so we don't duplicate
|
|
|
|
# all the tests; just one smoke test to ensure on_delete works for it as
|
|
|
|
# well.
|
2015-07-22 22:43:21 +08:00
|
|
|
o2o_setnull = models.ForeignKey(R, models.SET_NULL, null=True,
|
|
|
|
related_name="o2o_nullable_set")
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
def create_a(name):
|
|
|
|
a = A(name=name)
|
|
|
|
for name in ('auto', 'auto_nullable', 'setvalue', 'setnull', 'setdefault',
|
|
|
|
'setdefault_none', 'cascade', 'cascade_nullable', 'protect',
|
|
|
|
'donothing', 'o2o_setnull'):
|
|
|
|
r = R.objects.create()
|
|
|
|
setattr(a, name, r)
|
|
|
|
a.child = RChild.objects.create()
|
|
|
|
a.child_setnull = RChild.objects.create()
|
|
|
|
a.save()
|
|
|
|
return a
|
|
|
|
|
|
|
|
|
|
|
|
class M(models.Model):
|
|
|
|
m2m = models.ManyToManyField(R, related_name="m_set")
|
|
|
|
m2m_through = models.ManyToManyField(R, through="MR",
|
|
|
|
related_name="m_through_set")
|
|
|
|
m2m_through_null = models.ManyToManyField(R, through="MRNull",
|
|
|
|
related_name="m_through_null_set")
|
|
|
|
|
|
|
|
|
|
|
|
class MR(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
m = models.ForeignKey(M, models.CASCADE)
|
|
|
|
r = models.ForeignKey(R, models.CASCADE)
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
class MRNull(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
m = models.ForeignKey(M, models.CASCADE)
|
|
|
|
r = models.ForeignKey(R, models.SET_NULL, null=True)
|
2010-11-10 00:46:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
class Avatar(models.Model):
|
2012-09-20 23:51:30 +08:00
|
|
|
desc = models.TextField(null=True)
|
2008-06-22 04:55:17 +08:00
|
|
|
|
|
|
|
|
2010-11-10 00:46:42 +08:00
|
|
|
class User(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
avatar = models.ForeignKey(Avatar, models.CASCADE, null=True)
|
2008-06-22 04:55:17 +08:00
|
|
|
|
|
|
|
|
2010-11-10 00:46:42 +08:00
|
|
|
class HiddenUser(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
r = models.ForeignKey(R, models.CASCADE, related_name="+")
|
2008-06-22 04:57:05 +08:00
|
|
|
|
|
|
|
|
2010-11-10 00:46:42 +08:00
|
|
|
class HiddenUserProfile(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
user = models.ForeignKey(HiddenUser, models.CASCADE)
|
2012-09-20 23:51:30 +08:00
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2012-09-20 23:51:30 +08:00
|
|
|
class M2MTo(models.Model):
|
|
|
|
pass
|
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2012-09-20 23:51:30 +08:00
|
|
|
class M2MFrom(models.Model):
|
|
|
|
m2m = models.ManyToManyField(M2MTo)
|
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2012-09-20 23:51:30 +08:00
|
|
|
class Parent(models.Model):
|
|
|
|
pass
|
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2012-09-20 23:51:30 +08:00
|
|
|
class Child(Parent):
|
|
|
|
pass
|
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2012-09-20 23:51:30 +08:00
|
|
|
class Base(models.Model):
|
|
|
|
pass
|
|
|
|
|
2013-11-03 12:36:09 +08:00
|
|
|
|
2012-09-20 23:51:30 +08:00
|
|
|
class RelToBase(models.Model):
|
2015-07-22 22:43:21 +08:00
|
|
|
base = models.ForeignKey(Base, models.DO_NOTHING)
|