当前位置:  开发笔记 > 编程语言 > 正文

django - 在查询集上切片/过滤后过滤,其中结果已被限制

如何解决《django-在查询集上切片/过滤后过滤,其中结果已被限制》经验,为你挑选了2个好方法。

难以理解为什么我无法在查询集上切片后进行过滤以及发生了什么.

stuff = stuff.objects.all()
stuff.count()

= 7

如果我然后去

extra_stuff = stuff.filter(stuff_flag=id)
extra_stuff.count()

= 6.一切都很好,我的新查询集在extrastuff没有问题

stuff = stuff.objects.all()[:3]
extra_stuff = stuff.filter(stuff_flag=id)

我收到错误"切片一旦切片就无法过滤查询".

如何在我限制结果数量的查询集中进一步过滤?



1> Alasdair..:

filter()切片查询集后无法使用.错误非常明确.

Cannot filter a query once a slice has been taken.

你可以用Python做过滤器

stuff = stuff.objects.all()[:3]
extra_stuff = [s for s in stuff if s.stuff_flag=='flag']

要获取extra_stuff中的数字或项目,请使用 len()

extra_stuff_count = len(extra_stuff)

当Python的大小stuff非常小时,在Python中进行过滤可以正常工作,就像在这种情况下一样.如果你有一个更大的切片,你可以使用子查询,但是这也可能有性能问题,你必须测试.

extra_stuff = Stuff.objects.filter(id__in=stuff, stuff_flag='flag')



2> Daniel Rosem..:

Django为您提供了该错误,因为它已经从该点检索了数据库中的项目.该filter方法仅用于在实际执行数据库查询之前优化数据库查询.

由于你只获得了三个对象,你可以在Django中进行额外的过滤:

extra_stuff = [s for s in stuff if s.stuff_flag==id]

但我想知道为什么你在切片之前不做过滤器.

推荐阅读
重庆制造漫画社
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有