m0_50180798 2020-11-03 10:22 采纳率: 0%
浏览 38

想问问mongoose操作mongodb中嵌套文档的问题

刚接触时候没想那么复杂,感觉更新就是update,在ctx.request.body中有文档匹配的上的就更新,
没有匹配的上的就不更新。但是后面接触到了嵌套数组,发现好像只要涉及到了嵌套数组内的文档
,更新就变得复杂了很多
举个例子:

async updatecertificate(ctx){
        const {userid = "",certifitecateid =""} = ctx.params
        const {name, certificate_time, certificate_id, valid_period, 
               major, category, licensing_agency, licensing_imageurl}= ctx.request.body
        const user = await User.findById(userid)
        const certifitecate = await User.find({"professionaltitle._id":certifitecateid})
        if(!user || !certifitecate){ctx.body = {message:'用户不存在或者证照不存在'}}

        const succes = await User.update({"_id":userid, "professionaltitle._id":certifitecateid},
        { $set: {'professionaltitle.$.name':name,'professionaltitle.$.certificate_time':certificate_time,
                 'professionaltitle.$.certificate_id':certificate_id, 'professionaltitle.$.valid_period':valid_period, 
                 'professionaltitle.$.major':major, 'professionaltitle.$.category':category,'professionaltitle.$.licensing_agency':licensing_agency, 
                 'professionaltitle.$.licensing_imageurl':licensing_imageurl}})
        ctx.body = succes;
    }

感觉嵌套文档内的修改一定要一个柱对一条梁的感觉,并没有像普通文档那样用update的方法就可以很智能的识别 ctx.request.body中对应文档中的键值对那样,很不方便,不知道有哪位网友有类似的疑惑解决的可以帮忙解惑一下,问题有点低级,别见笑

  • 写回答

1条回答 默认 最新

  • lshen01 2023-03-16 17:09
    关注

    参考GPT和自己的思路:

    你的问题是关于使用Mongoose操作嵌套文档的更新问题。首先,你需要确保你已经在模型中定义了正确的嵌套文档结构。在使用update方法时,你需要指定匹配条件和要更新的内容。

    对于嵌套数组中的文档修改,可以使用 $ 路径占位符来指定要修改的数组元素的位置。例如,在你的示例中,你使用了以下内容来更新数组中的元素:

    'professionaltitle.$.name':name

    在这种情况下,“$”表示professionaltitle数组中与查找条件匹配的元素。这样,你可以更新特定的嵌套文档属性,而不是整个嵌套文档。

    你需要确保你在更新嵌套文档时,适当地使用 $ 路径占位符以便让Mongoose正确地识别出要更新的文档位置。

    评论

报告相同问题?

悬赏问题

  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示