gpt4 book ai didi

django - 查询集和切片的问题

转载 作者:行者123 更新时间:2023-12-01 23:44:30 25 4
gpt4 key购买 nike

我有 2 个模型,CompanyProduct,其中 Product 具有指向 Company 的外键

class Product(Meta):
company = models.ForeignKey(
Company,
related_name='products',
on_delete=models.CASCADE
)

我做了以下过滤:

 company = Company.objects.filter(account=account, pk=company_pk)
if not company:
raise Http404
product = Product.objects.filter(company=company, pk=product_pk)
if not product:
raise Http404
return product

我有以下错误:

The QuerySet value for an exact lookup must be limited to one result using slicing.

company_pkproduct_pk 只是变量。如果我删除“产品”过滤器,则不会出现错误。

我认为发生这种情况是因为公司结果是一个 QuerySet 并作为参数推送到 Product.objects.filter

最佳答案

正如已接受的答案中所述,公司是一个查询集。

The QuerySet value for an exact lookup must be limited to one result using slicing.

而不是这个

product = Product.objects.filter(company=company, pk=product_pk)

试试这个

product = Product.objects.filter(company__in=company, pk=product_pk)

__in 可以处理大于 1 的查询集(表的多个记录)。

这可以在文档的 django Many-to_one 关系部分找到。 https://docs.djangoproject.com/en/2.0/topics/db/examples/many_to_one/

Django 文档对于像我这样的初学者来说可能会很可怕,因为它的长度和深度,尽管它提供了大多数问题的解决方案(如果你能破解它)。

关于django - 查询集和切片的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47701679/

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