2016-06-07 227 views
0

我有一個視圖,允許您搜索課程並向您顯示已接受這些課程的個人資料(這又屬於一個用戶)。搜索工作正常,但問題是它不是基於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過濾數據,它只是給我提供所有數據。

+1

任何人都可以在沒有看到SafetyCoursesTaken的情況下回答問題嗎? – e4c5

+0

您是否要查看我的模特?如果需要,我可以提供。 – nastyn8

+0

是的,請在問題中添加模型。而且,還要添加你在查詢中傳遞的信息等。 – AKS

回答

1

我想通了。當我添加特定的課程時,它將課程添加到錯誤的用戶,因爲我使用self.request.user而不是通過self.kwargs ['pk']從URL中獲取該ID。

對不起,浪費了任何人的時間。

+2

只要你從中學到了它就沒有問題。你可以接受你自己的答案 – e4c5