nodejs mongodb es6-promises 使用外键数据获取列表

nodejs mongodb es6-promises fetch list with foreign key data

Whosebug/nodejs/mongo/promises/es6 的新手。我已经使用 promises 成功地创建了一些简单的查询和插入,但现在遇到了困难,所以我想我会寻求一些帮助。

我正在尝试通过查找创建者(所有者)和(锻炼)名称来检索例程列表,以挑选与例程相关的锻炼(一对一)。

我已经尝试过这里的想法 Aren't promises just callbacks? and 但似乎无法获得一个循环来处理平面链接的想法。

所以,在伪代码中

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。我现在希望获得有关我的解决方案的建议。

有一些关于组织思想和削减代码以在论坛上发帖的东西......我已经设法解决了这个问题,至少我有一些有用的东西。它 'look' 不适合我,当然也不平坦,所以如果你知道 better/proper 方式,请大声说出来,thanx。

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