Reviewers: teon.banek, florijan, mtomic, buda Reviewed By: teon.banek, buda Subscribers: mferencevic, pullbot Differential Revision: https://phabricator.memgraph.io/D1022
5.2 KiB
Examples
This chapter shows you how to use Memgraph on real-world data and how to get interesting and useful information out of it.
TED Talks Example
TED is a nonprofit organization devoted to spreading ideas, usually in the form of short, powerful talks. Today, TED talks are influential videos from expert speakers on almost all topics — from science to business to global issues. Here we present a small dataset which consists of 97 talks. We'll show you how to model this data as a graph and demonstrate a few example queries.
Data Model
Each TED talk has a main speaker, so we
identify two types of nodes — Talk
and Speaker
. Also, we will add
an edge of type Gave
pointing to a Talk
from its main Speaker
. Each speaker has a name
so we can add property name
to Speaker
node. Likewise, we'll add properties
name
, title
and description
to node Talk
.
Furthermore, each talk is given in a specific TED event, so
we can create node Event
with property name
and relationship InEvent
between talk and event.
Talks are tagged with keywords to facilitate searching, hence we
add node Tag
with property name
and relationship HasTag
between talk and
tag. Moreover, users give ratings to each talk
by selecting up to three predefined string values.
Therefore we add node Rating
with these values as property name
and relationship
HasRating
with property user_count
between talk and rating nodes.
Example Queries
We have prepared a database snapshot for this example, so you can easily import it
when starting memgraph using durability-directory
option:
./memgraph --durability-directory /usr/share/memgraph/examples/TEDTalk --durability-enabled=false
NOTE: If you modify dataset these changes will stay
Now you're ready to try out some of the following queries.
- Find all talks given by specific speaker:
MATCH (n:Speaker {name: "Hans Rosling"})-[:Gave]->(m:Talk)
RETURN m.title;
- Find the top 20 speakers with most talks given:
MATCH (n:Speaker)-[:Gave]->(m)
RETURN n.name, COUNT(m) as TalksGiven
ORDER BY TalksGiven DESC LIMIT 20;
- Find talks related by tag to specific talk and count them:
MATCH (n:Talk {name: "Michael Green: Why we should build wooden skyscrapers"})-[:HasTag]->(t:Tag)<-[:HasTag]-(m:Talk)
WITH * ORDER BY m.name
RETURN t.name, COLLECT(m.name), COUNT(m) AS TalksCount;
ORDER BY TalksCount DESC;
- Find 20 most frequently used tags:
MATCH (t:Tag)<-[:HasTag]-(n:Talk)
RETURN t.name as Tag, COUNT(n) AS TalksCount
ORDER BY TalksCount DESC, Tag LIMIT 20;
- Find 20 talks most rated as "Funny". If you want to query by other ratings, possible values are: Obnoxious, Jaw-dropping, OK, Persuasive, Beautiful, Confusing, Longwinded, Unconvincing, Fascinating, Ingenious, Courageous, Funny, Informative and Inspiring.
MATCH (r:Rating{name:"Funny"})<-[e:HasRating]-(m:Talk)
RETURN m.name, e.user_count ORDER BY e.user_count DESC LIMIT 20;
- Find inspiring talks and their speakers from the field of technology:
MATCH (n:Talk)-[:HasTag]->(m:Tag {name: "technology"})
MATCH (n)-[r:HasRating]->(p:Rating {name: "Inspiring"})
MATCH (n)<-[:Gave]-(s:Speaker)
WHERE r.user_count > 1000
RETURN n.title, s.name, r.user_count ORDER BY r.user_count DESC;
- Now let's see one real-world example — how to make a real-time recommendation. If you've just watched a talk from a certain speaker(e.g. Hans Rosling) you might be interested in finding more talks from the same speaker on a similar topic:
MATCH (n:Speaker {name: "Hans Rosling"})-[:Gave]->(m:Talk)
MATCH (t:Talk {title: "New insights on poverty"})-[:HasTag]->(tag:Tag)<-[:HasTag]-(m)
WITH * ORDER BY tag.name
RETURN m.title as Title, COLLECT(tag.name), COUNT(tag) as TagCount
ORDER BY TagCount DESC, Title;
The following few queries are focused on extracting information about TED events.
- Find how many talks were given per event:
MATCH (n:Event)<-[:InEvent]-(t:Talk)
RETURN n.name as Event, COUNT(t) AS TalksCount
ORDER BY TalksCount DESC, Event
LIMIT 20;
- Find the most popular tags in the specific event:
MATCH (n:Event {name:"TED2006"})<-[:InEvent]-(t:Talk)-[:HasTag]->(tag:Tag)
RETURN tag.name as Tag, COUNT(t) AS TalksCount
ORDER BY TalksCount DESC, Tag
LIMIT 20;
- Discover which speakers participated in more than 2 events:
MATCH (n:Speaker)-[:Gave]->(t:Talk)-[:InEvent]->(e:Event)
WITH n, COUNT(e) AS EventsCount WHERE EventsCount > 2
RETURN n.name as Speaker, EventsCount
ORDER BY EventsCount DESC, Speaker;
- For each speaker search for other speakers that participated in same events:
MATCH (n:Speaker)-[:Gave]->()-[:InEvent]->(e:Event)<-[:InEvent]-()<-[:Gave]-(m:Speaker)
WHERE n.name != m.name
WITH DISTINCT n, m ORDER BY m.name
RETURN n.name AS Speaker, COLLECT(m.name) AS Others
ORDER BY Speaker;
Now you're ready to explore the world of graph databases with Memgraph by yourself and try it on many more examples and datasets.
Graph Gists Examples
A nice looking set of small graph examples can be found here. You can take any use-case and try to execute the queries against Memgraph. To clear the database between trying out examples, execute the query:
MATCH (n) DETACH DELETE n;