首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如果存在于mongodb中的数组中,则移除数组

如果存在于mongodb中的数组中,则移除数组
EN

Stack Overflow用户
提问于 2020-05-20 09:28:53
回答 1查看 196关注 0票数 0
代码语言:javascript
复制
{
"_id" : ObjectId("5cca927ed5494b0"),
"userName": "1234",
"rcReviews": [{
        "userName": "qwert",
        "finalReview": "qtrwyw",
        "dField": [{
                "name": "t2",
                "status": "Not Verified",
                "reviewComment": "asdfag"
            },
            {
                "status": "Not Verified",
                "reviewComment": "asegqrt",
                "name": "t13"
            },
            {
                "name": "c452",
                "status": "Not Verified",
                "reviewComment": "gaeqrtqa "
            },
            {
                "status": "Not Verified",
                "reviewComment": "tyqiqooqa",
                "name": "c13"
            }
        ]
    },
    {
        "userName": "1517",
        "finalReview": "wsywx",
        "dField": [{
                "status": "Not Verified",
                "reviewComment": "aswrrwgqrt",
                "name": "t113"
            },
            {
                "name": "c1516",
                "status": "Not Verified",
                "reviewComment": "gaeqredectqa "
            },
        ]
    }
]}

我想要一个检查dField数组键是否存在于rcReveiws数组中的查询。如果它存在,那么它已经删除了dField数组,其他内容应该在那里,只应该删除dField数组。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-20 09:53:04

您可以使用以下查询。它已经用你提供的数据进行了测试

代码语言:javascript
复制
db.testmongo.update({"rcReviews.dField":{$exists:true}},{$unset:{"rcReviews.$[].dField":""}},{multi:true})

更改集合名称以与您的名称匹配。查询检查rcReviews数组中包含rcReviews属性的记录。它更新数组中的所有对象,并使用unset删除dField属性。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61909622

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档