繁体   English   中英

如何检查SET和WHERE上是否存在文档

[英]How to check if document exist on SET and WHERE

我正在尝试更新PITA非规范化数据库结构。 我知道已经有关于如何检查文档是否存在的答案甚至文档都非常清楚,但我无法找到任何可以检查文档是否存在于更新“set”和“where”的内容。

首先,我想在更新之前检查一个文档是否存在

 const staffRef = db.collection("staff").doc(uid)

    return staffRef.set({
        employeeProfile: employeeProfile
    }, {
            merge: true
        })...

有没有办法检查该文档是否存在于集合中,或者我应该先阅读它以查明该文档是否存在

    const staffRef = db.collection("staff").doc(uid)
    return staffRef.get()
        .then((doc) => {
            if (doc.exists) {
                return staffRef.set({
                    employeeProfile: employeeProfile
                }, {...

其次我想检查多个文件在哪里

const staffRef = db.collection("staff").where("employerId", "==", uid)
    const batch = db.batch()

    return staffRef.get()
        .then((querySnapshot) => {
            querySnapshot.forEach((doc) => {
                batch.update(doc.ref, { employerProfile: employerProfile })
            })...

如果存在,我应该在forEach之后阅读每个doc吗?

第一个答案:是的,对于单个文档,您必须首先使用get()方法来确定该文档是否存在。

对于DocumentSnapshot指向一个不存在的文件,任何数据访问将返回“未定义”。 您可以使用exists属性显式验证文档的存在。

第二个答案:不,如果是Query结果,您不需要检查每个文档:通过使用querySnapshot.forEach()循环获得的每个doc都存在。

QuerySnapshot包含零个或多个表示查询结果的DocumentSnapshot对象。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM