Hi, lets talk about graph databases.π A graph database is composed of two elements: nodes (vertices) and relationships (edges). A node is comparable to an entity in relational databases, the relationships connect the nodes. Properties are similar to attributes of a relational database, they are key-value pairs that can be stored on both nodes and relationships.
You can add labels to the nodes and relationships to specify their type. The data model of graph databases is called the labeled property graph model. Cypher is the query language for graphs. Here is an example for creating two nodes with a relationship:
CREATE (ee:Person { name: "Emil", from: "Sweden"})β[:WORKS_FOR]->(:Company {name: βGoogleβ})
It is a CREATE clause to create data.
- () parenthesis to indicate a node
- ee:Person: a variable 'ee' and label 'Person' for the new node
- {} brackets to add properties to the node
- [:WORKS_FOR]β specifies the relationship to the Company node.
If you now want to retrieve these nodes with their relationship write:
MATCH (ee:Person{name:βEmilβ}) β[:WORKS_FOR]->(m) RETURN *;
Neo4J is the most popular graph database managament system at the moment. On their website you can use a sandbox with predefined datasets to play around, on the picture I queried the βCrime Investigation Datasetβ. :) They also have a lot of info for beginners, find the link at the end.
What do you know about graph databases? Have a nice evening! :)
Reference: www.neo4j.com
Top comments (0)