gpt4 book ai didi

python - 如何使用 DetailView 中 PK(主键)字段以外的不同字段进行查询

转载 作者:行者123 更新时间:2023-12-05 08:23:26 25 4
gpt4 key购买 nike

网址.py

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

View .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

模型.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

为什么它给我

PAGE NOT FOUND: No title found matching the query.

最佳答案

事实上,您不必重写get_object 方法,您需要做的只是像这样定义一个合适的slug 字段(不是pk_url_kwarg):

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

here是源代码,如果你想看看后面发生了什么。

关于python - 如何使用 DetailView 中 PK(主键)字段以外的不同字段进行查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43728982/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com