如何在Firebase表上进行连接

时间:2014-09-07 15:50:52

标签: javascript firebase

我正在尝试从两个表中获取数据,例如(获取所有用户及其详细信息)

tableOne.on('users', function (snapshot) {
    userId = snapshot.val().userId; // line 1 (results like 1,2,3,4,5,6)
    anotherTable.child('userdetails').child(userId).once('value', function(mediaSnap) {
     // result // line 2
 });
});

但问题是第1行首先执行6次,然后第2行执行n次,导致每次查找'其中用户ID为 - 6' ...不支持加入在Firebase?

任何帮助都是apreciated

2 个答案:

答案 0 :(得分:7)

您的代码段有一个令人讨厌的副作用:

var userId;
tableOne.on('value', function (snapshot) {
    userId = snapshot.val().userId; // line 1 (results like 1,2,3,4,5,6)
    anotherTable.child('userdetails').child(userId).once('value', function(mediaSnap) {
        console.log(userId + ":" + mediaSnap.val().name);
    });
});

您并未将userId声明为变量,这意味着它将成为JavaScript中的全局变量。由于回调函数是异步执行的,因此很有可能在需要时全局值会发生变化。

解决方案只是让userId成为回调函数的局部变量:

tableOne.on('value', function (snapshot) {
    var userId = snapshot.val().userId; // line 1 (results like 1,2,3,4,5,6)
    anotherTable.child('userdetails').child(userId).once('value', function(mediaSnap) {
        console.log(userId + ":" + mediaSnap.val().name);
    });
});

这将确保在函数内捕获userId的每个值。

答案 1 :(得分:0)

列表加入的解决方案:

tableOne.orderByKey().on("value", function (snapshot) {
    //console.log(snapshot.val());
    snapshot.forEach(function (data) {
        tableTwo.once('value').then(function (info) {
            info = info.val();
        });
    });
});