我正在尝试查询Firebase数据库以获取按时间戳排序的数据。
1:这有效,但返回的数据不按时间戳排序:
router.get('/articles', function(req, res, next) {
admin.database().ref('articles').orderByChild('timestamp').once('value').then(function (snapshot) {
let articles = snapshot.val();
console.log(articles);
res.render('articles', articles);
});
});
2:这会返回我想要的按时间戳排序的数据(我可以在console.log中看到它),但是我收到了这个错误:
// /node_modules/express/lib/response.js:1003
// if (err) return req.next(err);
// ^
// TypeError: req.next is not a function
router.get('/articles', function(req, res, next) {
admin.database().ref('articles').orderByChild('timestamp').on('child_added', function (snapshot) {
let articles = snapshot.val();
console.log(articles);
res.render('articles', articles);
});
});
我不知道我做错了什么。我看到两个firebase数据库调用是不同的,一个是一次而然后(所以它必须是一个承诺......?)而另一个是在(所以我想这只是一个正常的回调......)。
你对这里发生的原因有什么看法吗?对不起,如果这是显而易见的,但我有点像初学者..
答案 0 :(得分:2)
对Firebase数据库执行查询时,可能会有多个结果。因此快照包含这些结果的列表。即使只有一个结果,快照也会包含一个结果的列表。
因此,在您的第一个示例中,snapshot
保留了它们:匹配节点的键,它们的值,和它们之间的顺序。当您调用snapshot.val()
时,此数据将转换为常规JSON对象,该对象没有空间容纳所有三条信息。此时订购信息将被删除。
解决方案是使用snapshot.forEach()
以正确的顺序循环匹配的节点。
admin.database().ref('articles').orderByChild('timestamp').once('value').then(function (snapshot) {
var articles = [];
snapshot.forEach(function(articleSnapshot)
articles.push(snapshot.val());
});
console.log(articles);
res.render('articles', articles);
});