rql从javascript中的密钥rethinkdb列表中获取多个文档

时间:2013-12-03 10:00:34

标签: javascript dynamic rethinkdb

我有一个“人”数据表,它有一个唯一的键“id”。我有一个id列表,我想要获取我将作为JSON数组从客户端发送到服务器的数据。服务器将该数据作为JSON数组接收。

现在有办法运行一个查询来获取每个ID的文档吗?

或者是我自己解析id并构建一个结果数组的唯一选择,然后将该数组发回。

到目前为止,我已尝试使用...

  • getAll - 但我不能让它工作,因为它接受动态数量的参数,我不知道如何将我的数组值更改为动态数量的参数。

    (例如......我希望能够做下面显示的,但我不能)

    r.db('vp').table('user').getAll(["0", "0", "99"])
    

    我只能这样做......

    r.db('vp').table('user').getAll("0", "0", "99")
    
  • expr和forEach - 如下所示,但我认为这不起作用。

    var arr = [];
    r.expr(["0", "0", "99"]).forEach(function(id) {
    
    })
    

4 个答案:

答案 0 :(得分:18)

您还可以将getAll与动态数组一起使用。你必须诉诸apply

var ids = [1,2,3];
var table = r.table("person");
table.getAll.apply(table, ids).run( connection, callback);

请注意,从1.12开始,你可以做到

var ids = [1,2,3];
r.table("person").getAll(r.args(ids)).run(connection, callback)

答案 1 :(得分:6)

简短回答:

r.expr([id1, id2, id3]).eqJoin(function(doc) { return doc; }, r.table("person"))

更长的答案:

有几种方法可以做到这一点。以上是我称之为规范的方式。让我们分析发生了什么:

首先使用r.expr([id1, id2, id3])我们将数组打包以将其发送到服务器。

然后我们调用eqJoin它所做的是获取值流并为每个值分派和索引getfunction(doc) { return doc; }是一个稍微丑陋的黑客,因为eqJoin需要映射功能。

所以最后上面的代码等同于:

[r.table("person").get(id1), r.table("person").get(id2), r.table("person).get(id3)]

答案 2 :(得分:1)

2017年更新。使用ES6传播运营商'...'

r.db('vp').table('user').getAll(...["0", "0", "99"])

答案 3 :(得分:0)

您可以将.expr.map一起使用,以获得.eqJoin

的更清晰替代方案
r.expr(array).map(function(id) {
  return r.table('user').get(id);
});