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