使用java

时间:2015-05-13 10:29:46

标签: java graph-databases orientdb gremlin tinkerpop

您好我是gremlin的新手,并尝试通过查找两个节点之间的所有路径来实现一些解决方案。在gremlin控制台上的简单查询中,我能够使用此查询执行此操作:

(Name of the first Node).loop(1){it.loops<100}{true}.has('name', (Name of the second node)).path{it.name}

但是当我试图从java方法中获取它时,我遇到了问题,例如:

- 没有关于准确放置查询的位置的线索? - 接收行数组的数据结构是什么。 - 如何从图中收集第一个节点和第二个节点。

在这里,我试图继续这一点,但没有任何线索:

  Graph g = new OrientGraph(AppConstants.GRAPH_LOCATION);
         List<String> vertexList = new ArrayList<String>();
         try{
             for (Vertex v : g.getVertices()) {
                    String vertexName = v.getProperty("name");
                    vertexList.add(vertexName);
                }    
             return vertexList;
         } catch (final Exception ex) {
             throw new AppSystemException(ex);
         }finally{
             g.shutdown();

谢谢, 萨厄尔

1 个答案:

答案 0 :(得分:2)

您的查询对我没有多大意义,但说明有帮助。以下是使用TinkerGraph查找markolop之间所有路径的示例:

final Graph g = TinkerGraphFactory.createTinkerGraph();
List<List> names = new ArrayList<>();
new GremlinPipeline<Vertex, ArrayList<Vertex>>(g).V().has("name", "marko").as("x").out().loop("x",
        new PipeFunction<LoopPipe.LoopBundle<Vertex>, Boolean>() {
            @Override
            public Boolean compute(LoopPipe.LoopBundle<Vertex> loopBundle) {
                return loopBundle.getLoops() < 100;
            }
        }, new PipeFunction<LoopPipe.LoopBundle<Vertex>, Boolean>() {
            @Override
            public Boolean compute(LoopPipe.LoopBundle<Vertex> loopBundle) {
                return "lop".equals(loopBundle.getObject().getProperty("name"));
            }
        }
).has("name", "lop").path(new PipeFunction<Vertex, String>() {
    @Override
    public String compute(final Vertex vertex) {
        return vertex.getProperty("name");
    }
}).fill(names);

names列表将填入以下两个条目:

  1. [marko,lop]
  2. [marko,josh,lop]
  3. 如果将Groovy转换为Java是最大的问题,那么你一定要检查一下:Converting Gremlin Groovy to Gremlin Java