在我的firestore数据库中,我在层次结构的不同部分使用相同的集合名称。例如,想象一个类似stackoverflow的站点,其中包含以下2个集合
/questions/{questionId}/votes/
/questions/{questionId}/answers/{answerId}/votes/
所以现在我想在这两个集合中的一个上创建一个索引。我希望firestore需要某种“路径与通配符”,就像我上面用来识别要编入索引的数据一样。但是,相反,它们只需要集合名称:在这种情况下,“投票”。
因此,如果我在“投票”上加上一个索引,它是否适用于这两个集合?有没有办法在其中一个集合上放置索引而不是另一个?使用唯一的集合名称来避免此问题是最佳做法吗?
答案 0 :(得分:7)
是即可。索引基于集合ID。这适用于我们在单个字段上自动为您创建的那些,以及您手动创建的复合索引。 如果它们是语义上不同的索引,我们建议您为它们提供唯一的ID,以便您可以使用Out-File
和question_votes
。
Collection id是集合的标识符,不包括完整路径。在您的情况下,正如您所指出的那样,这是answer_votes
。
我们当前提供的查询使用特定路径的索引子集,尽管我们将来有计划允许您执行跨越具有相同集合ID(集合组)的所有集合的查询。这一小部分信息为原因增加了一些背景。
第二个原因是系统中存在200个复合索引限制,因此如果某人的数据模型结构如下votes
,那么他们就没有真正的方法可以在blog_posts上创建复合索引对于少数用户而言(更不用说为每个用户创建新索引的操作负担了!)