当我在Arango中进行遍历时,我得到一个json结构数组,如下所示:
{
"vertex" : {
"_id" : "vertices/857831247835",
"_key" : "857831247835",
"_rev" : "857831247835",
},
"path" : {
"edges" : [
{
"_id" : "edges/857831575515",
"_key" : "857831575515",
"_rev" : "857831575515",
"_from" : "vertices/857831247835",
"_to" : "vertices/857821417435",
}
],
"vertices" : [
{
"_id" : "vertices/857821417435",
"_key" : "857821417435",
"_rev" : "857821417435",
},
{
"_id" : "vertices/857831247835",
"_key" : "857831247835",
"_rev" : "857831247835",
}
]
},
"startVertex" : "vertices/857821417435"
}
有没有办法让遍历中的所有边/顶点成为一个结构,就像上面使用AQL一样?
答案 0 :(得分:1)
您实际上可以使用两种方法来获得结果:
轻松扩展您的AQL查询:
FOR x IN (<<Your previous query here>>) RETURN {edges: x.path.edges, vertices: x.path.vertices, vertex: x.vertex, startVertex: x.startVertex}
更高效的方式(您将对象创建短路):
在以下位置注册用户定义的函数:https://docs.arangodb.com/AqlExtending/Functions.html
一次使用arangosh
。
这应该是这样的:
require("org/arangodb/aql/functions").register("myVisitors::flatVisitor",
function (config, result, vertex, path) {
result.push({ vertex: vertex, edges: path.edges, vertices: path.vertices});
});
然后在您的AQL中添加与visitor: "myVisitors::flatVisitor"
相同的附加选项paths: true
。
BTW:paths: true
在这种情况下将被忽略,因为它仅用于我们的默认访问者。
提示:如果您只需要结果中的某些属性而不是完整文档,则只需在访问者中返回这些属性。这将显着提高性能。
答案 1 :(得分:0)
有点旧,但为了这个问题的新访问者。 另一种方法是从路径中唯一地累积边缘(语法是arangojs官方客户端):
graph.traversal('verticies/startkey', {
direction: 'any',
init: `result.verticies = [];
result.edges = [];`,
visitor: `
path.edges
.forEach(function (x) {
if (result.edges.indexOf(x) === -1) {
result.edges.push(x);
}
});
result.verticies.push(vertex);
`,
uniqueness: {
"vertices": "global",
"edges": "global"
}
});