模型字段可自动存储俱乐部会员总数

时间:2019-10-30 20:14:25

标签: python django orm

我正在为一个慈善俱乐部构建一个应用程序,该应用程序有许多不同的用户,每个用户都属于一个俱乐部。我想每次用户注册特定学校的帐户时自动增加类“ 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',)

我知道这就像一个小问题,但是我一直到处都没有运气。对于解决此问题的任何投入将不胜感激,这将大大有助于该项目的其他方面。

1 个答案:

答案 0 :(得分:0)

我不确定自动递增total_members字段的重要性是什么。 Django具有超强大的查询功能。例如,这将完美地工作:

total_members = User.objects.filter(chapter__school_name="My Cool School").count()

注意,本章后面我使用双下划线来引用外键中的特定字段。

希望这会有所帮助。