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

Cam*_*art 8 javascript dynamic rethinkdb

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

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

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

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

neu*_*ino 18

您还可以将getAll与动态数组一起使用.你必须求助于apply

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

请注意,从1.12开始,您可以这样做

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


Joe*_*ner 6

简答:

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

更长的回答:

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

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

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

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

[r.table("person").get(id1), r.table("person").get(id2), r.table("person).get(id3)]
Run Code Online (Sandbox Code Playgroud)