Multiple graphs in a database
10-24-2019 12:34 AM
In the MR2 document, 3.1.3 states
In logical terms, a database is a container for one or more graphs. In MR2, a database is a container for one graph only.
What are good examples of having multiple graphs in a database vs multiple databases? When multiple graphs in a database are supported, would the transaction domain expand across multiple graphs?
- Labels:
-
Neo4j-4.0
10-24-2019 05:48 AM
Let me rephrase the vocabulary:
instance
: a JVM running Neo4j, potentially multiple databases
database
: a "graph space". Any query is run within a defined database and cannot break out of it. The very same
concept of "create database" e.g. in mysql. Different databases can have different permissions being set up.
graph
: a set of nodes/rels residing inside a database. Think about unconnected components.
A transaction is always on a database level, there's no notion of cross-database transactions.
A nice example of multiple databases: consider a large company where multiple departments work with graphs that need to be strictly separated for either legal or organizational reasons. IT doesn't want to maintain a bunch of different servers (or containers). So they could go with one instance (potentially clustered) and create a separate db for each department.