django queryset runtime - get nth entry in constant time(Django查询集运行时-在固定时间内获取第n个条目)
本文介绍了Django查询集运行时-在固定时间内获取第n个条目的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我使用多种方式通过不同的Django查询集从数据库获取数据, 但是我想知道每个查询集的运行时,如果可能的话,还有一个更好的方式(也许可以在固定时间内获取数据!)qs = MyModel.objects.order_by('-time')
qs = qs.filter(blah = blah)
要获取第一个条目,我执行以下操作:
entry = list(qs[:1])
first_entry = entry[0]
或获取第10个和最后一个条目:
entry = list(qs)
some_entry = entry[9]
last_entry = entry[-1]
但我相信这需要O(N)时间,有没有办法在固定时间内得到第n项?
我不想使用get(),因为我不知道条目(已排序)的ID或其他值,只知道位置。
我也可以使用Annotate,但这也需要O(N)个运行时间。
MyModel.objects.values('date').annotate(min_value=Min('value')).order_by('min_value')[0]
我知道该职位只需要在固定时间内录入该条目?
推荐答案
来自文档:
使用Python的数组切片语法的子集将QuerySet限制为一定数量的结果。这等效于SQL的LIMIT和OFFSET子句。
通常,对QuerySet进行切片会返回一个新的QuerySet-它不会计算查询。例外情况是使用Python Slice语法的"step"参数。若要检索单个对象而不是列表(例如,从条形图限制1中选择foo),请使用简单索引而不是切片。
https://docs.djangoproject.com/en/dev/topics/db/queries/#limiting-querysets
有关在对查询集进行切片时不对其求值的部分是重要的部分。
这篇关于Django查询集运行时-在固定时间内获取第n个条目的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
编程基础网
本文标题为:Django查询集运行时-在固定时间内获取第n个条目
基础教程推荐
猜你喜欢
- 与常规 dict 相比,Python manager.dict() 非常慢 2022-01-01
- 用 Python 编写 Fortran 无格式文件 2022-01-01
- 将 x 轴刻度更改为自定义字符串 2022-01-01
- 使用生成器和迭代器时 Python 多循环失败 2022-01-01
- 在 Celery 工作人员中捕获 Heroku SIGTERM 以优雅地关 2022-01-01
- numpy float:比算术运算中内置的慢 10 倍? 2022-01-01
- pyserial - 可以从线程 a 写入串行端口,是否阻塞从线程 b 读取? 2022-01-01
- 尝试制作WhatsApp机器人 2022-01-01
- Discord.py 缺少必需的参数 2022-01-01
- 由Python将MP3转换为MIDI(类型错误:无法加载插件:mtg-Melodia:Melodia) 2022-01-01
