久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

javascript - promise mongoose 循環遍歷查詢

瀏覽:107日期:2023-08-27 15:02:00

問題描述

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 的值?

問題解答

回答1:

自問自答吧,也是受人指點。

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 模塊即可:javascript - promise  mongoose 循環遍歷查詢

回答2:

由于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; }});

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产日韩视频在线观看 | 美女操网站| 国产精品久久久久久久久久久久久久久久 | 亚洲精品在线免费 | 国语精品久久 | 91麻豆精品国产91久久久更新资源速度超快 | 91精品中文字幕一区二区三区 | 美女超碰 | 91在线精品一区二区三区 | 日韩1区 | 五月激情综合 | 国产精品美女久久久久久免费 | 欧美激情视频一区二区三区在线播放 | 亚洲欧美另类在线 | 久久99精品久久久久蜜臀 | 精品中文久久 | 精品一区二区三区免费 | 久久久久久久91 | 山岸逢花在线观看 | 免费观看毛片 | 国产国拍亚洲精品av | 国产成人高清 | 亚洲视频免费在线观看 | 日本久久www成人免 成人久久久久 | av在线成人 | 久久久a | 亚洲视频综合 | 成人在线黄色 | 99热这里有精品 | 天天影视网色香欲综合网无拦截 | 国内外成人在线视频 | 欧美精品在线观看免费 | 麻豆久久久9性大片 | 日韩精品久久久久久 | 久久久www成人免费精品 | 91短视频版在线观看免费大全 | 伊人影院在线观看 | 日本久久精品视频 | 男人的天堂在线视频 | 午夜在线电影 | 日韩色综合 |