-
Notifications
You must be signed in to change notification settings - Fork 274
OrientDB Implementation
<dependency>
<groupId>com.tinkerpop.blueprints</groupId>
<artifactId>blueprints-orient-graph</artifactId>
<version>??</version>
</dependency>
// OPEN THE GRAPH 'tinkerpop' ON LOCAL FILE SYSTEM
Graph localGraph = new OrientGraph("local:/tmp/tinkerpop");
// OPEN THE GRAPH 'tinkerpop' ON REMOTE SERVER (localhost). THE SERVER COULD RUN IN DISTRIBUTED MODE
Graph remoteGraph = new OrientGraph("remote:localhost/tinkerpop");
// OPEN THE GRAPH 'tinkerpop' CREATING IN MEMORY ONLY
Graph remoteGraph = new OrientGraph("memory:tinkerpop");
Orient Technologies are the developers of OrientDB.
OrientGraph is transactional. This means that as soon as the graph is modified (add and remove vertex/edges, set properties) a new transaction is started automatically and it’s committed manually or at the graph shutdown.
supportsDuplicateEdges: true
supportsSelfLoops: true
supportsSerializableObjectProperty: true
supportsBooleanProperty: true
supportsDoubleProperty: true
supportsFloatProperty: true
supportsIntegerProperty: true
supportsPrimitiveArrayProperty: true
supportsUniformListProperty: true
supportsMixedListProperty: true
supportsLongProperty: true
supportsMapProperty: true
supportsStringProperty: true
ignoresSuppliedIds: true
isPersistent: true
isRDFModel: false
isWrapper: false
supportsIndices: true
supportsVertexIndex: true
supportsEdgeIndex: true
supportsKeyIndices: true
supportsVertexKeyIndex: true
supportsEdgeKeyIndex: true
supportsEdgeIteration: true
supportsVertexIteration: true
supportsTransactions: true
supportsThreadedTransactions: false
By default, OrientDB keeps a per-database instance cache of vertices and their properties. This can cause issues with concurrent access to the database where different threads will receive inconsistent results when querying the database after writes.
A way around this is to disable OrientDB’s L1 cache. This option can slow performance when doing certain graph operations. You can do this in code, before you create your graph with:
OGlobalConfiguration.CACHE_LEVEL1_ENABLED.setValue(false);
A more fine grained option is to have Orient force reload vertices when appropriate using ODocument’s reload() command:
((ODocument)((OrientVertex)vertex).getRawElement()).reload();
OrientDB supports custom types for vertices and edges in an Object Oriented manner. Even if this isn’t supported directly by Blueprints there are some tricks to use them. For more information look at Custom types.
OrientGraphNoTx is non transactional. This means that every non idempotent operations against the graph is atomic. Use this implementation to massive import graphs. Example:
// OPEN THE GRAPH 'tinkerpop' ON LOCAL FILE SYSTEM
Graph localGraph = new OrientGraphNoTx("local:/tmp/tinkerpop");
Since Blueprints 2.4.x the underlying structure used for graphs is changed to be much more lightweight. To open databases created with Blueprints 2.3.x or minor disable the new optimizations right after opened the graph:
Graph graph = new OrientGraph("local:/tmp/tinkerpop");
graph.setUseLightweightEdges(false);
graph.setUseClassForEdgeLabel(false);
graph.setUseClassForVertexLabel(false);
graph.setUseVertexFieldsForEdgeLabels(false);
// START USING IT