1

我有两个简单的表:

用户表:

{
"activated": true ,
"created": Wed Jun 22 2016 15:22:32 GMT+00:00 ,
"email": email@email.com, »
"id":  "5071f620-576a-49c0-ae84-e9f32db2a034" ,
"roles": [
"Admin"
] ,
"sso":  "123456789"
}

角色表:

{
"id":  "f62b1d29-84d1-4bad-a359-dacb8678f607" ,
"permissions": [
"add" ,
"delete"
] ,
"role":  "Admin"
}

我正在运行查询以获取给定用户的权限。我正在执行以下操作:

r.db('content').table("users").merge(function(user){
  return r.object(
    'permissions', user('roles').eqJoin(function(id){
      return id
    }, r.db('content').table('roles')).zip()('permissions')
    .reduce(function(left, right){
      return left.merge(right)
    })
    )      
});

但我收到一个错误:

Server error:

e: Cannot reduce over an empty stream

我做错了什么,为什么?我想要的输出会给我一个具有他们权限的用户。

4

1 回答 1

1

问题是它试图在roles表中查找带有idofAdmin而不是roleof的文档Adminrole假设您在表中有一个索引roles(如果没有,您可以通过编写添加一个r.db('content').table('roles').indexCreate('role')),您应该能够通过添加{index: 'role'}eqJoin调用来修复它。

r.db('content').table("users").merge(function(user){
  return r.object(
    'permissions', user('roles').eqJoin(function(id){
      return id
    }, r.db('content').table('roles'), {index: 'role'}).zip()('permissions')
    .reduce(function(left, right){
      return left.merge(right)
    })
    )      
});
于 2016-06-24T08:36:37.467 回答