2016-08-14 7 views
1

У меня есть Neo4j граф (созданный с помощью гном), и я хотел бы использовать его с помощью Gremlin, а также, однако, кодовые запросы на графике не похоже на работу:Tinkerpop Neo4j Cypher запросов не работает

import org.apache.tinkerpop.gremlin 
import gremlin.neo4j.structure.Neo4jGraph 
import gremlin.tinkergraph.structure.TinkerGraph 
import gremlin.hadoop.structure.HadoopGraph 
import org.apache.commons.configuration.Configuration 

trait Graph[G] { 
    def create(location: String, args: Configuration = null): G 
} 

object Grapher { 

    implicit val createNeo4j = new Graph[Neo4jGraph] { 
    def create(location: String, args: Configuration = null) = 
     if (args != null) Neo4jGraph.open(args) else Neo4jGraph.open(location) 
    } 

    implicit val createTinkerGraph = new Graph[TinkerGraph] { 
    def create(location: String, args: Configuration = null) = 
     if (args != null) TinkerGraph.open(args) else TinkerGraph.open() 
    } 

    implicit val createHadoopGraph = new Graph[HadoopGraph] { 
    def create(location: String, args: Configuration = null) = 
     if (args != null) HadoopGraph.open(args) else HadoopGraph.open(location) 
    } 
} 

object GraphSyntax { 
    def createGraph[G](location: String, args: Configuration = null)(implicit graph: Graph[G]) = graph.create(location, args) 
} 

Это, как я пытаюсь выполнить запрос:

import Grapher._ 
import GraphSyntax._ 

val graph = createGraph[Neo4jGraph](fileName) 
// org.apache.tinkerpop.gremlin.neo4j.structure.Neo4jGraph = neo4jgraph[community single [/media/ixaxaar/Source/src/telperion/core/neo4j.db]] 

graph.cypher("match (n) return n limit 10").toList 
// java.util.List[Nothing] = [] 

Если я загружаю граф в сервер Neo4j, тот же запрос работает на Neo4j веб-консоли.

match (n) return n limit 10 

neo4j output

Я использую следующие LIBS:

final val Gremlin     = "3.2.1" 
final val Neo4jTinkerpop   = "0.4-3.0.3" 
val gremlinCore  = "org.apache.tinkerpop" % "gremlin-core"    % Version.Gremlin 
val gremlinGiraph  = "org.apache.tinkerpop" % "giraph-gremlin"   % Version.Gremlin 
val gremlinNeo4j  = "org.apache.tinkerpop" % "neo4j-gremlin"   % Version.Gremlin 
val hadoopGremlin  = "org.apache.tinkerpop" % "hadoop-gremlin"   % Version.Gremlin 
val tinkergraphGremlin = "org.apache.tinkerpop" % "tinkergraph-gremlin"  % Version.Gremlin 
val neo4jTinkerpop  = "org.neo4j"    % "neo4j-tinkerpop-api-impl" % Version.Neo4jTinkerpop 
+0

Как вы обращаетесь к Нео с Гремлином? Вы можете порекомендовать те или иные библиотеки или библиотеки? – swelet

+0

Если у вас уже есть неографический граф, например. в 'val location =" ~/bin/neo4j-community-3.0.4/data/databases/graph.db "', вы можете загрузить его непосредственно в gremlin, используя 'Neo4jGraph.open (location)', откройте обход 'val t = graph.traversal() ', а затем выполните gremlin-запросы' val res = tV(). blah(). blah() ' Прочтите это для запросов обхода гремлина -> http://tinkerpop.apache.org/ docs/current/reference/# traversal – ixaxaar

+0

Кроме того, вы можете использовать cypher в gremlin, используя 'graph.cypher (" match your cypher-query ")' Обратите внимание на код выше (в scala), если вам нужен какой-нибудь шаблон. Зависимости sbt перечислены выше – ixaxaar

ответ

0

Очень жаль это, оказывается, я открывал новый граф (fileName неверен).

scala> graph.cypher("match (n) return n limit 10").toList 
res3: java.util.List[Nothing] = [{n=v[0]}, {n=v[1]}, {n=v[2]}, {n=v[3]}, {n=v[4]}, {n=v[5]}, {n=v[6]}, {n=v[7]}, {n=v[8]}, {n=v[9]}]