我是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' } } ]
提前感谢您的回复或回答。
答案 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响应将具有更早的日期/时间。