This module provides Cypher for Gremlin implementation of Neo4j driver interfaces.
It could be used as a drop in replacement to run Cypher queries via Neo4j Java API on Gremlin Server or a compatible graph database.
- Transaction functionality is not supported yet.
SummaryCounters
,StatementType
andTypeSystem
are not supported.
To add a dependency using Maven:
<dependency>
<groupId>org.opencypher.gremlin</groupId>
<artifactId>cypher-gremlin-neo4j-driver</artifactId>
<version>1.0.4</version>
</dependency>
To add a dependency using Gradle:
dependencies {
compile 'org.opencypher.gremlin:cypher-gremlin-neo4j-driver:1.0.4'
}
You can also build the snapshot from source.
Use org.opencypher.gremlin.neo4j.driver.GremlinDatabase
to create Gremlin Server-enabled driver instances (like org.neo4j.driver.v1.GraphDatabase
):
Driver driver = GremlinDatabase.driver("//localhost:8182");
It is also possible to create a driver from a org.apache.tinkerpop.gremlin.driver.Cluster
instance:
Cluster cluster1 = Cluster.build()
.enableSsl(true)
.addContactPoints("192.168.0.145")
//...
.create();
Driver driver1 = GremlinDatabase.driver(cluster1);
// Or:
Cluster cluster2 = Cluster.open(pathToGremlinConfiguration);
Driver driver2 = GremlinDatabase.driver(cluster2);
By default Cypher queries will be sent without translation, expecting Cypher plugin to be installed on the server. If the target Gremlin Server does not have the plugin installed, translation can be done on the client's thread:
Config config = Config.build()
.withTranslation()
.toConfig();
String uri = "//localhost:" + port;
Driver driver = GremlinDatabase.driver(uri, config);
Note that if Gremlin vertex and edge ids are non-numeric (for example UUID), queries that return nodes and relationships will fail, because Neo4j driver expects ids to be numeric.
You could write queries returning properties instead of entities or configure the driver to ignore ids (value will always be -1):
Config config = Config.build()
.ignoreIds()
.toConfig();
You will still be able to get original ids by using the id() function and query entities using original ids:
Config config = Config.build()
.withTranslation(TranslatorFlavor.gremlinServer())
.ignoreIds()
.toConfig();
Driver driver = GremlinDatabase.driver(uri, config);
try (Session session = driver.session()) {
StatementResult getOriginal = session.run("MATCH (n:VertexWithStringId) RETURN id(n) as id");
Object originalId = getOriginal.single().get("id").asObject();
assertThat(originalId).isEqualTo(uuid); // ef8b80c9-f8f9-40b6-bad2-ee4757d5bb33
StatementResult result = session.run("MATCH (n) WHERE id(n) = $originalId RETURN n", singletonMap("originalId", originalId));
Node n = result.single().get("n").asNode();
assertThat(n.id()).isEqualTo(-1); // -1
}
You can also execute Cypher directly against a GraphTraversalSource
:
TinkerGraph graph = TinkerFactory.createModern();
GraphTraversalSource traversal = graph.traversal();
Driver driver = GremlinDatabase.driver(traversal);
Otherwise, the API is the same:
try (Session session = driver.session()) {
StatementResult result = session.run("CREATE (a:Greeting) " +
"SET a.message = $message " +
"RETURN a.message",
parameters("message", "Hello"));
String message = result.single().get(0).asString();
assertThat(message).isEqualTo("Hello");
}