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,
...
}
]
我可以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,
...
}
]