nodejs mongodb es6-promises使用外键数据

时间:2016-03-26 21:44:54

标签: node.js mongodb es6-promise

stackoverflow / nodejs / mongo / promises / es6的新功能。我已经成功地创建了一些简单的查询和插入,使用了promises,但是我现在正面临着墙,所以我想请求一些帮助。

我正在尝试检索一个例程列表,其中包含查找创建者(所有者)和(锻炼)名称,以选择与常规相关的锻炼(1to1)。

我已尝试过Aren't promises just callbacks?How to chain and share prior results with Promises这些想法,但似乎无法使用平面链接理念进行循环。

所以,在伪代码中

getRoutineList
foreach routine:
    get user account using Routine.email
    get workout for Routine, using user._id and Routine.workout_name
    return the list of routines and workouts

我最初的想法是基于我目前的工作和有限的经验。

var rp = routines.find( {owner : user_id}).toArray().then( function( routine_list){
    for( var i =0; i<routine_list.length; i++){
        var routine = routine_list[i];
        var ap = accounts.find( {email:routine.creator}).toArray().then( function( creator){
            var workout_owner = creator[0];
            var creator_id = workout_owner._id.toHexString(); // .toString();

            var wp = workouts.find( { owner : creator_id, name : routine.ofWorkout})
                                .toArray().then( function( workout_list ){
                return workout_list;
            });
            that.promises.push( wp);
            console.log( "add workout promise count:", that.promises.length);
        });
        that.promises.push(ap);
        console.log( "add account promise count:", that.promises.length);
    }
    return routine_list;
});
that.promises.push( rp);
console.log( "add routine promise count:", that.promises.length);


Promise.all( that.promises).then( function( promise_results){
    console.log( "promises count:", that.promises.length);
    console.log( "promises complete, data:", promise_results);

    var data = {};
    data["routines"] = promise_results[0];
    var workouts = [];
    for( var i = 1; i<promise_results.length; i++){
        workouts.push( promise_results[i]);
    }
    data["workouts"] = workouts;

    res.status(200).send( [promise_results]);
});

在这里尝试编辑 - 这个问题是关于承诺链,而不是循环内的闭包 - JavaScript closure inside loops – simple practical example。我现在希望就我的解决方案提出建议。

1 个答案:

答案 0 :(得分:1)

有关于组织思想和减少代码以便在论坛中发布的内容...我已经设法解决了问题,至少我有一些有用的东西。它没有看起来&#39;对我而言当然不是平的,所以如果你知道一个更好/更合适的方式,请说出来,而不是。

var rp = new Promise( function( resolve, reject){
    routines.find( {owner : user_id}).toArray()
    .then( function( results){
        results.forEach( function( obj, ndx, arr){
            accounts.find( {email:obj.creator}).next( function( e, acc){
                // obj.creator_account = acc;
                obj.creator_id = acc._id.toHexString();
                workouts.find( { owner : obj.creator_id, name : obj.ofWorkout}).next( function( e, workout){
                    console.log( "got workout:", workout);
                    obj.workout = workout;
                    if( ndx === arr.length-1) resolve( results);
                });
            });
        });
    });
}).then( function( results){
    console.log( "results:", results);
    res.status(200).send( results);
});