Node.js API为同一请求返回不同的值

时间:2016-11-03 00:25:47

标签: javascript ajax node.js express reactjs

我正在学习使用Node.js + Express来构建REST API。在这个API中 我有以下方法:

  apiRouter.route('/training/session/byId/:id_session')
  // ===== GET =======
  .get(function(req, res) {

    //Get the session
    Session.findById(req.params.id_session, function(err, session) {

      //Get an array of exercise associated with the session
      Exercise.find({session: session._id}, function(err, exercise) {
        let movements = [];
        let sets = [];
        let i = exercise.length-1;

        //For every exercise get the movements and the sets
        exercise.forEach(function (ex,index) {
          Movement.findById(ex.movement,function(err,movement){
            if(movement)
              movements.push(movement);

            //***** Here?
            Set.find({exercise: ex}, function (err, set) {
              if(set.length)
                sets.push(set);
              if(index == i){
                res.json({ message: 'ok' ,session,exercise,movements,sets});
              }
            })
          })
        })
      });
    });
  })

这个想法是从数据库中获取所有与会话相关的信息。

首先:   我认为这不是制作多个查询并使用所有查询信息返回对象的正确方法,但我是Node的异步工作的新手......那么制作多个查询的正确方法是什么一个查询的数据取决于其他查询?

第二:在前端(React + Redux)我使用axios发出Ajax请求,并且对于相同的Ajax请求,有时并非所有'设置'被取出(// *****这里?)。问题出在API?

提前致谢。

编辑:数据库模型

会话:

var SessionSchema   = new Schema({
  date: {type: Date, default: Date.now },
  time: Number, //Time in seconds
  user: {required: true, type: mongoose.Schema.Types.ObjectId, ref: 'User'},

});

练习:

var ExerciseSchema   = new Schema({
    session: {type: mongoose.Schema.Types.ObjectId, ref: 'Session'},
    movement: {type: mongoose.Schema.Types.ObjectId, ref: 'Movement'},
  timestamp: {
        type: Date,
        default: Date.now
      }
});

集:

var SetSchema   = new Schema({
    repetitions: Number,
  weight: Number,
  rest: Number,
  timestamp: {
        type: Date,
        default: Date.now
      },
    exercise : {type: mongoose.Schema.Types.ObjectId, ref: 'Exercise'}

});

机芯:

var MovementSchema   = new Schema({
    name:  { type: String, required: true, index: true, unique: true },
  material:{ type: String, required: true},
  muscles : [{
    name : { type: String, required: true},
    percentage : { type: Number, required: true}
     }]
});

1 个答案:

答案 0 :(得分:0)

/Users/luna/Documents/Ethan/scripts/microglia.sh: line 16: cd: /Volumes/Israel\ Hernandez/Quantitative\ Data/Microglia\ data/3\ month/Mutant/314a/: No such file or directory

当然,我的上一个答案是行不通的。 set查询回调将在if(index == i)之后执行。实际上我不确定这会从你的代码产生不同的结果。我从来没有真正使用过Mongoose,但就我所知,你不能做连接,所以嵌套查询就是这样做的。

您可能需要考虑使用promises。没有必要,但它们使您的代码更易于阅读和思考:http://eddywashere.com/blog/switching-out-callbacks-with-promises-in-mongoose/

创建一个在查询返回时构建的单个结果对象可能更有意义,因此您最终会发送一个代表您的会话的JSON对象,如下所示:

Set.find({exercise: ex}, function (err, set) {  
if(set.length)
    sets.push(set);      
}).then(function(set){
    if(index == i){
        res.json({ message: 'ok' ,session,exercise,movements,sets});
    }
})