django关键字不能是表达式

时间:2013-06-07 22:51:49

标签: django django-models django-queryset

我正在尝试创建一个查询,我在其中获得了一个筛选列表。

我调用查询的模型是:

class WorkoutRecord(models.Model):

    challenge = models.ForeignKey(Challenge)

    workout_email_sent = models.DateTimeField(default=datetime.now)

    status = models.IntegerField(default=1) 

我的查询是:

L = WorkoutRecord.objects.filter(status = 1, challenge.user = request.user, workout_email_sent__lt = today)

我收到的错误消息是:

  

关键字不能是表达式

我知道问题出现在查询的challenge.user = request.user部分,但我不确定如何编写查询,以便正确过滤此ForeignKey

1 个答案:

答案 0 :(得分:25)

使用__跟踪查询集中的外键关系:

L = WorkoutRecord.objects.filter(status=1, challenge__user=request.user, workout_email_sent__lt=today)