Django4.0 数据库访问优化-如果你明确需要它,那么立即检索所有内容。
2022-03-16 18:02 更新
对于你需要的所有部分的单个数据集的不同部分,多次访问数据库比单次查询所有内容的效率低。如果有一个查找,它在循环中执行,这点就尤其重要,当只需要一个查询时,最终会执行许多数据库查询。因此:
使用 QuerySet.select_related() 和 prefetch_related()
深入理解 select_related()
和 prefetch_related()
,并使用它们:
- 在 管理器和默认管理器 中使用。请注意管理器何时被使用;有时这很棘手,所以不要做出假设。
- 在视图代码层或其他层中,可能在需要时使用
prefetch_related_objects()
。
以上内容是否对您有帮助:
更多建议: