您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

为什么要遍历大型Django QuerySet消耗大量内存?

为什么要遍历大型Django QuerySet消耗大量内存?

ate C距离很近,但不太远。

从文档:

你可以通过以下方式评估QuerySet:

for e in Entry.objects.all():
    print e.headline

因此,当你第一次进入该循环并获得查询集的迭代形式时,一次就可以检索一千万行。你遇到的等待是Django加载数据库行并为每个数据库行创建对象,然后返回实际上可以迭代的内容。然后,你将所有内容存储在内存中,结果溢出了。

根据我对文档的阅读,iterator()仅能绕过QuerySet的内部缓存机制。我认为一件一件一件地做是有意义的,但是相反,这需要对数据库进行一千万次单独点击。也许不是所有想要的。

Go 2022/1/1 18:22:46 有536人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶