如何使用DetailView中的PK(主键)字段以外的其他字段进行查询

时间:2017-05-02 02:06:49

标签: python django sqlite listview detailview

url.py

urlpatterns = [
    url(r'^employee/(?P<emp_no>[0-9]+)/$', TitleDetail.as_view(), name='e-title'),  
    # /employee/10001/
    ]

views.py

class TitleDetail(DetailView):
    model = Title
    pk_url_kwarg = "emp_no"

    def get_context_data(self, **kwargs):
        context = super(TitleDetail, self).get_context_data(**kwargs)
        context['title_list'] = Title.objects.filter(emp_no_id=self.kwargs['emp_no'])
        return context

models.py

class Title(models.Model):
    emp_no = models.ForeignKey(Employee)
    title = models.CharField(max_length=50)
    from_date = models.DateField()
    to_date = models.DateField()

数据库中的示例数据:

id          title            from_date   to_date     emp_no_id 
----------  ---------------  ----------  ----------  ----------
1           Senior Engineer  1986-06-26  9999-01-01  10001     
2           Staff            1996-08-03  9999-01-01  10002  

为什么它会给我

  

未找到页面:未找到与查询匹配的标题。

2 个答案:

答案 0 :(得分:2)

事实上,您不必覆盖get_object方法,您需要做的只是定义一个适当的slug字段(不是pk_url_kwarg),如下所示:

class TitleDetail(DetailView):
    model = Title
    slug_field = "emp_no"
    slug_url_kwarg = "emp_no"

here是源代码,如果您想了解背后发生了什么。

答案 1 :(得分:0)

您可以覆盖get_object()方法以执行任何操作:

def get_object(self, queryset=None):
    queryset = self.get_queryset() if queryset is None else queryset
    return get_object_or_404(queryset, emp_no_id=self.kwargs['emp_no'])

如果您之前没有看过,请参阅get_object_or_404() documentation