我是Node.JS的新手。我正在使用CouchDB和Cradle。在couchDB中,我有一个名为"test"的数据库,其中我有一个名为"exercise"的文档。该文档有两个字段:"FullName"one_answers"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' } } ]
提前感谢您的任何回应或回答
尝试将http_res.send()调用移动到提供给db的回调中。查看-匿名函数(err, res) {}.
我不确定但是关于。foreach语句,你只会得到最后一个值从你的查询在响应变量,你应该看看,以及。
spotica is right
db。视图函数是异步的,所以http_res.end(response)在视图返回任何数据之前被调用。
您可以通过在console.log和http_res.end
中返回日期来证明这一点console.log(res, new Date())
和
http_res.end(response, new Date());
http响应将具有较早的日期/时间。