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正确地识别出要更新的文档位置。

    评论

报告相同问题?

悬赏问题

  • ¥20 关于php录入完成后,批量更新数据库
  • ¥15 请教往复密封润滑问题
  • ¥15 cocos creator发布ios包
  • ¥15 comsol压电材料数据
  • ¥35 用python实现除法算法中goldschmidt算法
  • ¥15 汇编代码转换成C代码
  • ¥15 除法算法中的归一化具体是怎么变的?
  • ¥20 集成电路的逻辑电路和晶体管简化图
  • ¥15 下载windows builder后的问题
  • ¥15 端口连接数为什么会有限制