nol*_*nis 9 firebase google-cloud-firestore
我知道通过数组中不存在的值进行查询非常困难,但是有没有办法做到这一点而不完全这样做?
这是我的场景 - 我有一个基于订阅的服务,人们可以选择加入并“关注”特定的艺术家。在我的后端,这会创建一个订阅文档,其中包含他们的 followerId、他们想要关注的艺术家的 id(称为artistId)以及一个名为 push 的数组。艺术家可以添加新版本,然后在未来向每个关注者发送特定歌曲的通知。我想跟踪哪个随从被推送到哪个版本,这在前面提到的推送数组中完成。我需要一种方法来找到哪些关注者已经被推送了一个特定的版本,所以......
我正在考虑组合两个查询,但我不确定是否可能。就像是:
db.collection('subscriptions').where('artistId', '==', artistId)db.collection('subscriptions').where('artistId', '==', artistId).where('pushed', 'array-contains', releaseId)然后取两个查询结果的交集并从第一个查询中减去以获得尚未推送特定版本的关注者。
这可能吗?或者,还有更好的方法?
无法在 Firestore 中查询没有特定字段或值的文档。这并不是“非常困难”,而是根本不可能。要了解更多原因,请参阅:
您的解决方法是可能的,而且从技术上来说甚至不是很复杂。唯一要记住的是,您需要加载所有艺术家。因此,性能将与您拥有的艺术家数量成线性关系。目前这可能适合您的应用程序,但绝对需要对其进行一些测量。
通常,我的解决方法是不跟踪向用户推送了哪些版本,而是跟踪最后一次推送发送给用户的时间。假设某个版本有一个“通知发送时间戳”,每个用户都有一个“最后收到的通知时间戳”。通过比较两者,您可以查询尚未收到有关特定版本的通知的用户。
确切的数据模型将取决于您的具体用例,并且您可能需要跟踪每个用户的多个时间戳(例如,他们关注的每个艺术家)。但我发现一般来说我可以根据这个模型提出一个合理的解决方案。
| 归档时间: |
|
| 查看次数: |
3199 次 |
| 最近记录: |