正确定义Django DB中的关系

时间:2013-03-20 20:45:46

标签: python sql django

我正在开发一款健身游戏网络应用。这个想法是每个星期都有一定数量的任务,一个人必须在下周发布之前完成。到目前为止,这是应用程序的models.py架构:

来自django.db导入模型 来自django.contrib.auth.models导入用户

class WeekOne(models.Model):
    squats = models.PositiveIntegerField()
    lunges = models.PositiveIntegerField()
    skipStairs = models.BooleanField()
    stairDaysCount = models.PositiveSmallIntegerField()
    # Set to true if (squats == 1000), (lunges == 250), 
    # (skipStairs is True), and (stairDaysCount == 3)
    weekOneComplete = models.BooleanField()

class UserProfile(models.Model):
    user = models.OneToOneField(User)
    weekOne = models.ForeignKey(WeekOne)

我迷失了几点。首先,显然我希望每个用户能够跟踪他们自己的进度,而没有任何其他用户能够看到它。让weekOne成为ForeignKey最好的方法吗?如果是这样,一旦定义了这种关系,如何访问每个用户的数据?例如,如果我想创建一个addSquats函数,我会做这样的事情:

user = UserProfile()
user.squats += 5

还是我必须做一些其他的魔法来到深蹲场?

其次,每当用户改变他们的进度(即添加深蹲或冲刺)时,我想检查所有字段是否都符合某个基准。如果有,我想将weekOneComplete设置为true。当用户单击按钮时,每个添加都将由一些javascript触发 - 但是我会在哪里放置检查/更新数据库的函数?

3 个答案:

答案 0 :(得分:1)

要访问第一周的字段,您需要执行以下操作:

user.weekOne.squats += 5
user.weekOne.save()

实际上,最好使用F函数并执行(或类似):

user.weekOne.squats = F('squates') + 5

一般来说,最好还是在服务器端进行所有检查,而不是依赖客户端(JS或其他)。例如,您公开一个URL并检查它们是整数的所有POST参数(例如转换为整数)

答案 1 :(得分:1)

对于你的第二个问题:一种可能的(而且简单的)这样做的方式,因为你说你正在使用javascript,是通过ajax调用。

它应该指向一个url,它本身指向一个视图,它将处理你在请求中发送的数据。一些事情(比如你正在使用POST请求):

def add(request):
    if not request.is_ajax():
        raise ...
    excercise, amount = request.POST['excercise'], request.POST['amount']
    user = request.user

    # a model method that'll add to whatever activity 
    # the user did and update the "week one complete" field
    user.did_activity(excercise, amount) 
    if user.weekOne.weekOneComplete:
        return HttpResponse(json.dumps(some_return_data), mimetype="application/json")
    return HttpResponse(json.dumps(other_return_data), mimetype="application/json")

这更像是伪代码的一面,所以你明白了。您仍然需要在JS端编写ajax调用,该模型方法将添加到正确的练习并验证基准,并将用户保存到数据库。例如:

def did_activity(self, excercise, amount):
    if excercise == 'squats':
        self.weekOne.squats += amount
    ...
    if self.hit_benchmark():
        self.weekOne.weekOneComplete = True
    self.save()

此外,此示例假定用户已通过身份验证。

祝你好运。

答案 2 :(得分:1)

首先,显然我希望每个用户都能够跟踪自己的进度而没有任何其他用户能够看到它。

在模板中,您可以这样做

 User: {{ user.username }}
 squats: {{ user.userprofile.squats }} 
 lunges: {{ user.userprofile.lunges }}
 Skip Stairs: 
    {% if user.userprofile.skipStairs %}
       Yes
    {% else %}
       No
    {% endif %}
 Stair: {{ user.userprofile.stairDaysCount }}}
 Week Completed: 
    {% if user.userprofile.weekOneComplete %}
        Yes
    {% else %}
        In-Progress
    {% endif %}

定义此关系后,如何访问每个用户的数据?例如,如果我想创建一个addSquats函数。

要访问用户数据,

user = UserProfile(user=request.user)
user.weekOne.squats += 5
user.weekOne.save()
user.save()

其次,每当用户对其进度进行更改(即添加深蹲或刺激)时,我想检查所有字段是否都符合某个基准。如果有,我想将weekOneComplete设置为true。

在您的UserProfile模型下,创建检查更新功能。

class UserProfile(models.Model):
    user = models.OneToOneField(User)
    weekOne = models.ForeignKey(WeekOne)

    def check_updates(self):
        check = WeekOne.object.get(id=self.weekOne)

        if check.skipStairs and \
           check.squats == 1000 and \
           check.lunges == 250 and \
           check.stairDaysCount == 3:

           check.weekOneComplete = True
           check.save()

因此,每次更新该用户的数据时,只需调用以下方法:

user = UserProfile.objects.get(user=request.user)
user.check_updates()