我正在为一个慈善俱乐部构建一个应用程序,该应用程序有许多不同的用户,每个用户都属于一个俱乐部。我想每次用户注册特定学校的帐户时自动增加类“ Club_Chapter”的“ total_members”字段(因此,用户外键“章”)。
models.py
class Club_Chapter(models.Model):
club_id = models.IntegerField(primary_key=True)
school_name = models.CharField(max_length=30)
state = models.CharField(max_length=4)
total_members = models.IntegerField(null = False, default = 0)
def __str__(self):
return self.school_name
# User Model
class User(AbstractUser):
username = None
email = models.EmailField(_('email address'), unique=True)
USERNAME_FIELD = 'email'
chapter = models.ForeignKey('Club_Chapter',on_delete=models.PROTECT)
ranking = models.CharField(default='member', max_length=20)
REQUIRED_FIELDS = []
objects = UserManager()
forms.py
class SignUpForm(UserCreationForm):
first_name = forms.CharField(max_length=30, required=True)
last_name = forms.CharField(max_length=30, required=True)
email = forms.EmailField(max_length=254, required=True)
chapter = models.ForeignKey('Club_Chapter',on_delete=models.PROTECT)
password2 = None
# below is my failed attempt to solve this problem
Club_Chapter.objects.update(total_members=F('total_members') + 1)
class Meta:
model = User
fields = ('first_name', 'last_name',
'chapter','email', 'password1',)
我知道这就像一个小问题,但是我一直到处都没有运气。对于解决此问题的任何投入将不胜感激,这将大大有助于该项目的其他方面。
答案 0 :(得分:0)
我不确定自动递增total_members
字段的重要性是什么。 Django具有超强大的查询功能。例如,这将完美地工作:
total_members = User.objects.filter(chapter__school_name="My Cool School").count()
注意,本章后面我使用双下划线来引用外键中的特定字段。
希望这会有所帮助。