我最近遇到了一些奇怪的行为,需要检查一下我的理解。
我在模型中使用了一个简单的过滤器,然后迭代结果。
例如
allbooks = Book.objects.filter(author = 'A.A. Milne')
for book in allbooks:
do_something(book)
奇怪的是,它只返回了部分书籍清单。
但是,当使用相同的代码并使用iterator()时,这似乎运行良好。
即
for book in allbooks.iterator():
do_something(book)
知道为什么??
附:我确实浏览了django文档,但看不出qeuryset如何在其他任何地方缓存...
iterator()
计算QuerySet(通过执行查询)并在结果上返回一个迭代器。 QuerySet通常在内部缓存其结果,以便重复的评估不会导致其他查询;iterator()
而是直接读取结果,而不在QuerySet级别进行任何缓存。对于返回大量对象的QuerySet,这通常会带来更好的性能并显着降低内存注意使用
iterator()
在已经评估的QuerySet上将强制它再次评估,重复查询。