Return 在 AQL 中具有动态键的对象

Return object with dynamic keys in AQL

我可以return这样的东西吗:

{
"c/12313" = 1,
"c/24223" = 2,
"c/43423" = 3,
...
}

来自 AQL 查询?这个想法是这样的(这个非工作代码):

for c in my_collection
return { c._id : c.sortOrder }

其中 sortOrder 是我文档中的一些 属性。

是的,有可能 dynamic attribute names:

LET key = "foo"
LET value = "bar"
RETURN { [ key ]: value } // { "foo": "bar" }

计算属性键的表达式必须包含在 [ 方括号 ] 中,如 JavaScript.

然而,这return并不完全是预期的结果:

FOR c IN my_collection
  RETURN { [ c._id ]: c.sortOrder }

[
  { "c/12313": 1 },
  { "c/24223": 2 },
  { "c/43423": 3 },
  ...
]

为了不 return 为每个键分离对象,需要 MERGE() 和一个子查询:

RETURN MERGE(
  FOR c IN my_collection
    RETURN { [ c._id ]: c.sortOrder }
)

[
  {
    "c/12313": 1,
    "c/24223": 2,
    "c/43423": 3,
    ...
  }
]