我知道通过数组中不存在的值进行查询非常困难,但是有没有办法做到这一点而不完全这样做?
这是我的场景 - 我有一个基于订阅的服务,人们可以选择加入并“关注”特定的艺术家。在我的后端,这会创建一个订阅文档,其中包含他们的 followerId、他们想要关注的艺术家的 id(称为artistId)以及一个名为 push 的数组。艺术家可以添加新版本,然后在未来向每个关注者发送特定歌曲的通知。我想跟踪哪个随从被推送到哪个版本,这在前面提到的推送数组中完成。我需要一种方法来找到哪些关注者已经被推送了一个特定的版本,所以......
我正在考虑组合两个查询,但我不确定是否可能。就像是:
db.collection('subscriptions').where('artistId', '==', artistId)db.collection('subscriptions').where('artistId', '==', artistId).where('pushed', 'array-contains', releaseId)然后取两个查询结果的交集并从第一个查询中减去以获得尚未推送特定版本的关注者。
这可能吗?或者,还有更好的方法?