首页 > 解决方案 > 有没有办法更新云功能中的集合组

问题描述

我正在构建一个聊天应用程序。当用户在他们的本地配置文件上进行更新时,我想使用云功能在 collectionGroup 中进行更新。

我正在成功收听云功能中的更新,并使用以下内容检索 collectionGroups 列表:

        const collectionGroupNameref = await db.collectionGroup('collectionGroupName').where('userId', '==', data.uid).get();


collectionGroupNameref.forEach(async (val: any) => {
            const connectionsRef = await db.collection('collectionGroupName').doc(val.id).get();
 
        });

但是现在我需要更新该 collectionGroup 中的一个字段,这就是我遇到问题的地方。

collectionGroup 存储在 2 个位置:

users{id}collectionGroupName{id}
groups{id}collectionGroupName{id}

是否可以更新该 collectionGroup 中的所有文档

标签: javascriptnode.jsfirebasegoogle-cloud-firestore

解决方案


Firestore 不提供任何方法来更新整个集合或集合组,例如 SQL 中的“UPDATE WHERE”。相反,您需要做的是单独编写每个文档。因此,如果您已经对集合组中的文档执行了查询,您是否可以简单地迭代结果集中的文档并根据需要更新每个文档。您可以使用DocumentSnapshot的 ref 属性轻松更新每个文档,无论它包含哪个集合。

const querySnapshot = await db
    .collectionGroup('collectionGroupName')
    .where('userId', '==', 'data.uid')
    .get();
querySnapshot.docs.forEach(snapshot => {
    snapshot.ref.update(...)
})

推荐阅读