Tinkerpop:プロパティを持つ頂点へのパスを持たない頂点を選択します
Aug 21 2020
Tinkerpopで、プロパティがfoo
等しい頂点に直接接続されていない頂点を選択したいbar
例:
Vertex user1 = graph.addVertex("vid","one");
Vertex user2 = graph.addVertex("vid","two");
Vertex user3 = graph.addVertex("vid","three");
Vertex tag1 = graph.addVertex("tagKey", "tagKey1");
Vertex tag2 = graph.addVertex("tagKey", "tagKey2");
Vertex tag3 = graph.addVertex("tagKey", "tagKey3");
user1.addEdge("user_tag", tag1);
user2.addEdge("user_tag", tag2);
user2.addEdge("user_tag", tag3);
上記のテストケースuser
ではtagKey
、値がtagKey2
。のタグ頂点に接続されていないすべての頂点を選択します。出力は2つの頂点である必要がありますuser3 , user 1
回答
1 codetiger Aug 21 2020 at 15:55
タグに接続されていない頂点をフェッチするためのクエリ。
g.V().hasLabel("Vertex").
filter(
not(outE().hasLabel('connected'))
).
properties()
頂点データを追加するためのクエリ:
g.addV('Vertex').as('1').property(single, 'name', 'One').
addV('Vertex').as('2').property(single, 'name', 'Two').
addV('Vertex').as('3').property(single, 'name', 'Three').
addV('Vertex').as('4').property(single, 'name', 'Four').
addV('Tag').as('5').property(single, 'name', 'Key1').
addV('Tag').as('6').property(single, 'name', 'Key2').
addV('Tag').as('7').property(single, 'name', 'Key3').
addE('connected').from('1').to('5').
addE('connected').from('2').to('6').
addE('connected').from('4').to('7')
Gremlifyリンク: https://gremlify.com/f1muf12xhdv/2
1 noam621 Aug 21 2020 at 15:58
これはnot
、次のwhere
手順を組み合わせて使用することで実現できます。
g.V().hasLabel('User').
not(where(out('user_tag').has('tagKey', 'tagKey2'))).
valueMap().with(WithOptions.tokens)
例: https://gremlify.com/jybeipj4zjg