mongoose怎么处理多层嵌套查询,变为链式操作

发布于 2022-09-04 03:15:07 字数 1753 浏览 12 评论 0

如果mongoose的查询需要嵌套多层(下面我只写了3层),并且下一层的查找需要上一层的查询结果,可能还会有其他操作,这样写起来会很乱,不易维护,怎么去变为链式的调用,避免多层嵌套。

    var Article = mongoose.model('Article');
    var User = mongoose.model('User');
    var Comment = mongoose.model('Comment');
    app.get("/article/:id",function(req,res,next){
        Article.find({_id:req.parems.id},function(err,article){
            if(err){console.log(err)}
            User.findOne({_id:article.author},function(err,user){
                if(err){console.log(err)}
                Comment.find({userId:user._id},function(err,comment){
                    if(err){console.log(err)}
                    res.redirect("/")   
                })
            })
        })
    })
    

我尝试这么去写

    var Article = mongoose.model('Article');
    var User = mongoose.model('User');
    var Category = mongoose.model('Category');
    var Comment = mongoose.model('Comment');
    app.get("/article/:id",function(req,res,next){
    
    var funMain = function(){//主函数
        Article.find({_id:req.parems.id},function(err,article){
            if(err){console.log(err)}
            fun2(article.author)
        })
    }
    
    var fun2 = function(author){//根据文章作者id查询用户
        User.findOne({_id:author},function(err,user){
                if(err){console.log(err)}
                fun3(user._id)
            })
    }
    
    var fun3 = function(userId){//根据用户id查询评论
        Comment.find({userId:userId},function(err,comment){
                    if(err){console.log(err)}
                    res.redirect("/")  //重定向 
                })
    }
    
    funMain()
    })
    

不知道有没有其他更好的方法

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

清浅ˋ旧时光 2022-09-11 03:15:07

推荐 使用 promise 包装 回调函数,或者使用mongoose 轻量orm框架,直接返回promise, 并且配合 async/await 进行出。。。这样就不用写这么多回调了

暖树树初阳… 2022-09-11 03:15:07

题主,有结果吗?

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文