Node.JS摇篮和couchDB帮助

时间:2013-05-12 14:26:12

标签: node.js couchdb cradle

我是Node.JS的菜鸟。 我正在使用CouchDB和Cradle。 在couchDB中,我有一个名为'test'的数据库,在其中我有一个名为'exercise'的文档。 该文档有两个字段:“FullName”和“Age”。 保存数据的代码如下:

var cradle = require('cradle');
var connection = new(cradle.Connection)('http://127.0.0.1', 5984, {
    auth: { username: 'toto_finish', password: 'password' }
});

var db = connection.database('test');
db.save('exercise', {
    FullName: param_name, Age: param_age
}, function (err, res) {
    if (err) {
        // Handle error
        response += ' SAVE ERROR: Could not save record!!\n';
    } else {
        // Handle success
        response += ' SUCESSFUL SAVE: The record was saved in CouchDB!\n';
    }
    http_res.end(response);
});

此代码运行良好,并将数据保存到CouchDB。 我的问题是我想读取数据。 我写的代码是:

  var cradle = require('cradle');
  var connection = new(cradle.Connection)('http://127.0.0.1', 5984, {
      auth: { username: 'toto_finish', password: 'password' }
  });

  var db = connection.database('test');
  db.view('exercise/all', {descending: true}, function(err, res)
  {
          console.log(res);
      res.forEach(function (row) {
          response = 'FullName: ' + row.FullName + '\n Age: ' + row.Age + '\n';
      });
  });
  http_res.end(response);

当我试图打印回复时,回复是空的,我不知道我做错了什么。我知道它不会进入forEach循环,但我不明白为什么。

控制台输出是:

[ { id: 'exercise',
    key: null,
    value:
     { _id: 'exercise',
       _rev: '1-7042e6f49a3156d2099e8ccb3cc7d937',
       FullName: 'Toto Finish',
       Age: '30' } } ]

提前感谢您的回复或回答。

2 个答案:

答案 0 :(得分:0)

尝试在提供给db.view的回调中移动http_res.send()调用 - 匿名函数(err,res){}。

我不确定.forEach语句,你只会从 response 变量中获取查询的最后一个值,你也应该查看它。

答案 1 :(得分:0)

spotirca是对的

db.view函数是异步的,因此在视图返回任何数据之前会调用http_res.end(response)。

您可以通过在console.log和http_res.end

中返回日期来证明这一点
console.log(res, new Date())

http_res.end(response, new Date());

http响应将具有更早的日期/时间。