5

arangodb プロジェクトの Web サイト全体を検索しましたが、解決策が見つかりませんでした。大陸/国/首都などのグラフのような単純なツリーをたどると、現在のアイテムのブレッドクラムを取得するにはどうすればよいですか? それが理にかなっていることを願っています

4

1 に答える 1

8

arangosh と Gremlin.JS を使用した例から始めます。後で、すべての言語ドライバーで利用できる AQL を使用します。

arangosh [_system]> var Graph = require("org/arangodb/graph").Graph;

まず、さまざまな場所 (地域、都市):

arangosh [_system]> v1 = g.addVertex("Earth");
arangosh [_system]> v2 = g.addVertex("Europe");
arangosh [_system]> v3 = g.addVertex("Germany");
arangosh [_system]> v4 = g.addVertex("Berlin");
arangosh [_system]> v5 = g.addVertex("Spain");
arangosh [_system]> v6 = g.addVertex("Barcelona");

とそれらの関係:

arangosh [_system]> g.addEdge(v1, v2);
arangosh [_system]> g.addEdge(v2, v3);
arangosh [_system]> g.addEdge(v3, v4);
arangosh [_system]> g.addEdge(v2, v5);
arangosh [_system]> g.addEdge(v5, v6);

これで、グラフがツリーになります。

arangosh [_system]> v1.outbound().getInVertex()
[ Vertex("Europe") ]

arangosh [_system]> v1.outbound().getInVertex().outbound().getInVertex()
[  [  Vertex("Germany"),  Vertex("Spain") ] ]

arangosh [_system]> v1.outbound().getInVertex().outbound().getInVertex().outbound().getInVertex()
[  [  [  Vertex("Berlin")  ],  [  Vertex("Barcelona")  ]  ]  ]

たとえばベルリンからブレッドクラムを取得するには、ベルリンから地球へのパスを計算できます。

arangosh [_system]> v4.pathTo(v1);
[
  [
    "Berlin",
    "Germany",
    "Europe",
    "Earth"
  ]
]

AQL を使用すると、トラバーサルを使用してベルリンからルートに戻ることができます。

arangosh [_system]> db._query('FOR p in TRAVERSAL(locations, part, @start, "inbound", {}) RETURN p.vertex._key', { start: v4._id } ).toArray()
[
  "Berlin",
  "Germany",
  "Europe",
  "Earth"
]

この例でパンくずリストの作成方法がわかると思います。

乾杯フランク

于 2013-11-30T16:57:55.060 に答える