javascript - promise mongoose 循環(huán)遍歷查詢(xún)
問(wèn)題描述
let result = []; //存放查詢(xún)結(jié)果model.WithdrawModel.find({status:’processing’}, (err, doc) => { if (err) {console.log(err);res.json({ code: -1, msg: ’查詢(xún)失敗’});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: ’查詢(xún)成功’, result: result});return; } });
循環(huán)遍歷查詢(xún),上述 result 直接返回空值,請(qǐng)問(wèn)怎么保證 doc.map 內(nèi)部的查詢(xún)都結(jié)束之后再取出 result 的值?
問(wèn)題解答
回答1:自問(wèn)自答吧,也是受人指點(diǎn)。
promise.all 實(shí)現(xiàn)如下:
let result = []; //存放查詢(xún)結(jié)果let doc1 = []; //存放第一次查詢(xún)的結(jié)果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返回的結(jié)果是一一對(duì)應(yīng)的 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: ’查詢(xún)成功’, result: result});return; });}).catch((e) => { console.log(e); res.json({ code: -1, msg: ’查詢(xún)失敗’}); return;});
--------------------------------------補(bǔ)充-------------------------------------------------
計(jì)數(shù)的思想仍然是可以實(shí)現(xiàn)的,使用 event 模塊即可:
由于Promise是異步調(diào)用,所以在所有的查詢(xún)之后使用return,會(huì)在還沒(méi)真正獲取到數(shù)據(jù)之后就返回,所以需要Promise內(nèi)添加一個(gè)計(jì)數(shù)器count,在所有的Promise下,加一個(gè)循環(huán),當(dāng)所有的doc都循環(huán)到了(count == doc.length),才可以輸出返回。
const deasync = require(’deasync’); // 引入deasync包...let result = []; //存放查詢(xún)結(jié)果model.WithdrawModel.find({status: ’processing’}, (err, doc) => { if(err) {console.log(err);res.json({code: -1, msg: ’查詢(xún)失敗’});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: ’查詢(xún)成功’, result: result});return; }});
相關(guān)文章:
1. 文本處理 - 求教使用python庫(kù)提取pdf的方法?2. JAVA 版本問(wèn)題?3. python - 有沒(méi)有關(guān)于Pyhton web開(kāi)發(fā)的相關(guān)論壇或者書(shū)?4. java - Spring Mvc全局異常處理器@ControllerAdvice不起作用?5. html5 - vue怎么實(shí)現(xiàn)像京東天貓banner圖片圖片點(diǎn)擊放大,并可滑動(dòng)到下一張6. css - 使手機(jī)版可左右托移?7. html5和Flash對(duì)抗是什么情況?8. 為什么我ping不通我的docker容器呢???9. html5 - 百度echart官網(wǎng)下載的地圖json數(shù)據(jù)亂碼10. javascript - Vue.js2.0不能使用debounce后大伙一般是如何解決延遲請(qǐng)求的問(wèn)題的呢。
