编程语言
首页 > 编程语言> > rql从javascript中的密钥rethinkdb列表中获取多个文档

rql从javascript中的密钥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) {

})

解决方法:

简答:

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

更长的回答:

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

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

然后我们调用eqJoin它所做的是获取值的流,并为每个值分配和索引获取.函数(doc){return doc;因为eqJoin需要一个映射函数,所以是一个稍微丑陋的黑客攻击.

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

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

标签:rethinkdb,javascript,dynamic
来源: https://codeday.me/bug/20191006/1861342.html