15

我在一个名为“English”的集合中有如下所示的 JSON 数据,为此我正在使用 MongoDB 驱动程序设置一个带有 nodejs 应用程序的 REST api。如果我执行以下操作,我将获得浏览器中返回的所有 JSON 数据。

app.get('/sentences', function (req, res){

     db.collection('english', function(err, collection) {
        collection.find().toArray(function(err, items) {

            res.send(items);
        });
    });

})

但是,当我尝试去/sentences/1获取一条记录时,应用程序冻结(浏览器选项卡中的半月形变慢)并且没有记录错误。我这样做 findOne 的方式有问题吗?

app.get('/sentences/:id', function(req,rest){

     var query = { 'question' : req.params.id };
     console.log(query);
     console.log('query');

    db.collection('english', function(err, collection) {

        collection.findOne(query, function(err, item) {
            console.log(err);
            res.send(item);
        });
    });
});

JSON数据

[
  {
    "_id": "526c0e21977a67d6966dc763",
    "question": "1",
    "uk": "blah blah blah",
    "us": "blah blah balh"
  },
  {
    "_id": "526c0e21977a67d6966dc764",
    "question": "2",
    "uk": "Tom went outside for a fag. I think he smokes too much!",
    "us": "Tom went outside for a cigarette. I think he smokes too much!"
  },
  {
    "_id": "526c0e21977a67d6966dc765",
    "question": "3",
    "uk": "Do you fancy going to the cinema on Friday?",
    "us": "How about going to the movies on Friday"
  }
]

更新

发生的事情是应用程序最终超时,我No data received在浏览器中收到一条消息。

4

3 回答 3

16

nodejs mongodb findOne by id

已经很晚了,但会对其他人有所帮助。

var id = new require('mongodb').ObjectID('58fcf02b1ab5de07e2a1aecb');//req.params.id
db.collection('users').findOne({'_id':id})
 .then(function(doc) {
        if(!doc)
            throw new Error('No record found.');
      console.log(doc);//else case
  });
于 2017-04-24T19:58:47.050 回答
4

问题是其中一个参数中的拼写错误(“res”中的一个额外的“t”)。代替

app.get('/sentences/:id', function(req,rest){
...

res.send(item);

本来应该

app.get('/sentences/:id', function(req,res){ 
...

res.send(item);
于 2013-10-28T02:08:22.517 回答
0

这不好,但仍然会对其他人有所帮助。

var id = new require('mongodb').ObjectID('58fcf02b1ab5de07e2a1aecb');//req.params.id
db.collection('users').findOne({'_id':id})
 .then(function(doc) {
        if(!doc)
            throw new Error('No record found.');
      console.log(doc);//else case
  });
于 2018-06-11T10:33:44.897 回答