我有一个名为 Collection 的 Django 模型,它表示项目的集合(CollectionItem)。每个集合仅包含特定类型的项目。(CollectionItem 有一个 Collection 的外键)。
我想获取特定类型的公共标记列表中的所有 CollectionItem,并按特定字段排序返回它们。这是我使用的查询代码:
lists = Collection.objects.filter(is_public=True, type=7)
items = CollectionItem.objects.none()
for list in lists:
items |= CollectionItem.objects.filter(collection=list)
items = items.order_by('name')
我不得不想象当我有一个包含大量列表和项目的大型数据库时,这根本不会很好地扩展。在 Django 中有没有更好的方法来做到这一点?或者与我不应该太担心的其他选项相比,查询循环中涉及的低效率是否可以忽略不计?