Django过滤器不按user_id过滤

时间:2016-06-07 10:12:41

标签: python django django-views

我有一个视图,允许您搜索课程并向您显示已经参加这些课程的个人资料(其中又属于用户)。搜索工作正常,但问题是它没有基于user_id进行过滤。

models.py

class EmployeeProfile(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL,  on_delete=models.CASCADE)
    first_name = models.CharField(max_length=30)
    middle_name = models.CharField(max_length=30, null=True, blank=True)
    last_name = models.CharField(max_length=30)

    def __str__(self):
        return self.first_name + ' ' + self.last_name

class SafetyCourse(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
    name = models.CharField(max_length=128, unique=True)

    def __str__(self):
        return self.name


class SafetyCoursesTaken(models.Model):
    user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE)
    profile = models.ForeignKey(EmployeeProfile, on_delete=models.CASCADE)
    course = models.ForeignKey(SafetyCourse, on_delete=models.CASCADE)
    conducted_date = models.DateTimeField(null=True, blank=True)
    expiration_date = models.DateTimeField(null=True, blank=True)

    class Meta:
        verbose_name_plural = 'Safety Courses Taken'

Views.py

class CourseSearchView(LoginRequiredMixin, SuccessMessageMixin, generic.ListView):
    login_url = reverse_lazy('users:login')
    template_name = 'ppm/forms/search-courses.html'

    def get_queryset(self):
        pk = self.kwargs['pk']
        query = self.request.GET.get('q')
        # verify proper foreign key is being passed
        print(pk)
        if query:
            # for lookups that span relationships go here: https://docs.djangoproject.com/en/1.9/topics/db/queries/
            return SafetyCoursesTaken.objects.filter(Q(course__user_id=pk) & Q(course__name__icontains=query))

现在,我已经检查了是否正在传递正确的外键,但是对于一个用户,它显示所有课程,而对于第二个用户,它不显示任何课程。

我尝试了许多不同的过滤器变体,但没有奏效:

SafetyCoursesTaken.objects.filter(Q(course__user_id=pk) & Q(course__name__icontains=query))

SafetyCoursesTaken.objects.filter(Q(course__name__icontains=query),
                                                 user_id=pk)

SafetyCoursesTaken.objects.filter(Q(course__name__icontains=query)).filter(user_id=pk)

SafetyCoursesTaken.objects.filter(user_id=pk).filter(Q(course__name__icontains=query))

但这些都没有奏效。我错过了什么?

注意:我传递的查询是" 10小时",我通过kwargs从URL获取外键。就像之前提到的。搜索正在运行并获取正确的数据,只是因为它没有根据发送的ID过滤数据,它只是向我提供了所有数据。

1 个答案:

答案 0 :(得分:1)

我明白了。当我添加特定课程时,它将课程添加到错误的用户,因为我使用self.request.user而不是通过self.kwargs [' pk']从URL中获取id。

很抱歉浪费了所有人的时间。