9

我有一个“人”数据表,它有一个唯一的键“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

4 回答 4

19

您还可以将 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)
于 2013-12-04T03:33:09.377 回答
7

简短的回答:

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

更长的答案:

有几种方法可以做到这一点。以上就是我所说的规范方式。让我们分解发生了什么:

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

然后我们称它的作用是获取一个值流并为每个eqJoin值分配和索引。getfunction(doc) { return doc; }是一个有点难看的hack,因为eqJoin需要一个映射函数。

所以最后上面的代码就相当于:

[r.table("person").get(id1), r.table("person").get(id2), r.table("person).get(id3)]
于 2013-12-03T11:01:24.747 回答
4

2017 年更新。使用 ES6 扩展运算符“...”

r.db('vp').table('user').getAll(...["0", "0", "99"])
于 2017-05-05T15:41:11.317 回答
0

您可以使用.exprwith.map作为更清洁的替代品.eqJoin

r.expr(array).map(function(id) {
  return r.table('user').get(id);
});
于 2017-06-30T00:28:35.067 回答