我有一个视图,允许您搜索课程并向您显示已接受这些课程的个人资料(这又属于一个用户)。搜索工作正常,但问题是它不是基于user_id进行过滤。Django过滤器不按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过滤数据,它只是给我提供所有数据。
任何人都可以在没有看到SafetyCoursesTaken的情况下回答问题吗? – e4c5
您是否要查看我的模特?如果需要,我可以提供。 – nastyn8
是的,请在问题中添加模型。而且,还要添加你在查询中传递的信息等。 – AKS