promise mongoose 循环遍历查询

发布于 2022-09-05 03:07:52 字数 1069 浏览 10 评论 0

let result = []; //存放查询结果
model.WithdrawModel.find({status:'processing'}, (err, doc) => {
            if (err) {
                console.log(err);
                res.json({ code: -1, msg: '查询失败'});
                return;
            } else {
                doc.map((item) => {
                    model.UserModel.findOne({phone:item.phone},'name IDcard bank bankCard bank_area bank_name', (err, bankInfo) => {
                        if (err) {
                            console.log(err);
                        } else {
                            let obj = {};
                            Object.assign(obj, JSON.parse(JSON.stringify(item)), JSON.parse(JSON.stringify(bankInfo)));
                            result.push(obj);
                            console.log(result); 
                        }
                    })
                });
                res.json({ code: 0, msg: '查询成功', result: result});
                return;
            }
 });

循环遍历查询,上述 result 直接返回空值,请问怎么保证 doc.map 内部的查询都结束之后再取出 result 的值?

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

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

发布评论

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

评论(2

诗酒趁年少 2022-09-12 03:07:52

自问自答吧,也是受人指点。

promise.all 实现如下:

        let result = []; //存放查询结果
        let doc1 = []; //存放第一次查询的结果
        model.WithdrawModel.find({status:'processing'}).exec().then((doc) => {
            doc1 = doc;
            const promises = doc.map(item => model.UserModel.findOne({phone:item.phone},'name IDcard bank bankCard bank_area bank_name'));
            return Promise.all(promises);
        })
        .then((bankInfoList) => {//promise.all返回的结果是一一对应的
            for(let i=0; i<doc1.length; i++){
                let obj = {};
                
                Object.assign(obj, JSON.parse(JSON.stringify(doc1[i])), JSON.parse(JSON.stringify(bankInfoList[i])));
                result.push(obj);
            }
            return new Promise((resolve, reject) => {
                    resolve(result);
            })           
        })
        .then((result) => {
            return new Promise(() => {
                res.json({ code: 0, msg: '查询成功', result: result});
                return;
            });
        })
        .catch((e) => {
            console.log(e);
            res.json({ code: -1, msg: '查询失败'});
            return;
        });

--------------------------------------补充-------------------------------------------------

计数的思想仍然是可以实现的,使用 event 模块即可:
图片描述

忆沫 2022-09-12 03:07:52

由于Promise是异步调用,所以在所有的查询之后使用return,会在还没真正获取到数据之后就返回,所以需要Promise内添加一个计数器count,在所有的Promise下,加一个循环,当所有的doc都循环到了(count == doc.length),才可以输出返回。

const deasync = require('deasync'); // 引入deasync包
...
let result = []; //存放查询结果
model.WithdrawModel.find({status: 'processing'}, (err, doc) => {
    if(err) {
        console.log(err);
        res.json({code: -1, msg: '查询失败'});
        return;
    } else {
        let count = 0, len = doc.length;

        doc.forEach((item, index) => {
            model.UserModel.findOne({phone: item.phone}, 'name IDcard bank bankCard bank_area bank_name', (err, bankInfo) => {
                if (err) {
                    console.log(err);
                } else {
                    let obj = {};
                    Object.assign(obj, JSON.parse(JSON.stringify(item)), JSON.parse(JSON.stringify(bankInfo)));
                    result.push(obj);
                    console.log(result); 
                }

                count++;
            });
        });

        deasync.loopWhile(() => count < len);

        res.json({code: 0, msg: '查询成功', result: result});
        return;
    }
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文