-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathmovies.neo4j-browser-guide
697 lines (656 loc) · 24.9 KB
/
movies.neo4j-browser-guide
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
<style type="text/css" media="screen">
/*
.nodes-image {
margin:-100;
}
*/
@import url("//maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css");
.imageblock .content img, .image img {max-width: 100%;}
.deck h3, .deck h4 {display: block !important;margin-bottom:8px;margin-top:5px;}
.listingblock {margin:8px;}
.pull-bottom {position:relative;bottom:1em;}
.admonitionblock td.icon [class^="fa icon-"]{font-size:2.5em;text-shadow:1px 1px 2px rgba(0,0,0,.5);cursor:default}
.admonitionblock td.icon .icon-note:before{content:"\f05a";color:#19407c}
.admonitionblock td.icon .icon-tip:before{content:"\f0eb";text-shadow:1px 1px 2px rgba(155,155,0,.8);color:#111}
.admonitionblock td.icon .icon-warning:before{content:"\f071";color:#bf6900}
.admonitionblock td.icon .icon-caution:before{content:"\f06d";color:#bf3400}
.admonitionblock td.icon .icon-important:before{content:"\f06a";color:#bf0000}
.admonitionblock.note.speaker { display:none; }
</style>
<style type="text/css" media="screen">
/* #editor.maximize-editor .CodeMirror-code { font-size:24px; line-height:26px; } */
</style>
<article class="guide" ng-controller="AdLibDataController">
<carousel class="deck container-fluid">
<!--slide class="row-fluid">
<div class="col-sm-3">
<h3>What is Cypher?</h3>
<p class="lead">Information</p>
<!dl>
</dl>
</div>
<div class="col-sm-9">
<figure>
<img style="width:300px" src=""/>
</figure>
</div>
</slide-->
<style type="text/css">
.smallest {
font-size:0.6em;
}
</style>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>What is Cypher?</h3>
<br/>
<div>
<div class="paragraph">
<p>Cypher is a graph query language that is used to query the Neo4j Database. Just like you use SQL to query a MySQL database,
you would use Cypher to query the Neo4j Database.</p>
</div>
<div class="paragraph">
<p>A simple Cypher query can look something like this</p>
</div>
<div class="exampleblock">
<div class="content">
<div class="paragraph">
<p>This content is only revealed when the user clicks the block title.</p>
</div>
</div>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie)
WHERE m.released > 2000
RETURN m LIMIT 5<!--/code--></pre>
</div>
</div>
<div style="background: #5CA6D9EE; padding: 12px; color: white; border-radius: 2px">
Hint: You can click on the query above to populate it in the editor.
</div>
<div class="paragraph">
<p><strong>Expected Result</strong>: The above query will return all the movies that were released after the year 2000 limiting the result to 5 items.</p>
</div>
<div class="imageblock">
<div class="content">
<img src="https://guides.neo4j.com/sandbox/movies/img/5-movies.svg" alt="5 movies" width="100%">
</div>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Write a query to retrieve all the movies released after the year 2005.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie)
WHERE m.released > 2005
RETURN m<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
<li>
<p>Write a query to return the count of movies released after the year 2005. (Hint: you can use the <code>COUNT(m)</code> function to return the count)</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie)
WHERE m.released > 2005
RETURN count(m)<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Nodes and Relationships</h3>
<br/>
<div>
<div class="paragraph">
<p>Nodes and Relationships are the basic building blocks of a graph database.</p>
</div>
<div class="paragraph">
<p><strong>Nodes</strong></p>
</div>
<div class="paragraph">
<p>Nodes represent entities. A node in graph database is similar to a row in a relational database.
In the picture below we can see 2 kinds of nodes - <code>Person</code> and <code>Movie</code>. In writing a Cypher query, a node is enclosed between a</p>
</div>
<div class="paragraph">
<p>parenthesis — like <code>(p:Person)</code> where <code>p</code> is a variable and <code>Person</code> is the type of node it is referring to.</p>
</div>
<div class="imageblock">
<div class="content">
<img src="https://guides.neo4j.com/sandbox/movies/img/schema.svg" alt="schema" width="100%">
</div>
</div>
<div class="paragraph">
<p><strong>Relationship</strong></p>
</div>
<div class="paragraph">
<p>Two nodes can be connected with a relationship. In the above image <code>ACTED_IN</code>, <code>REVIEWED</code>, <code>PRODUCED</code>, <code>WROTE</code> and <code>DIRECTED</code> are all
relationships connecting the corresponding types of nodes.</p>
</div>
<div class="paragraph">
<p>In writing a cypher query, relationships are enclosed in square brackets - like <code>[w:WORKS_FOR]</code> where <code>w</code> is a variable and <code>WORKS_FOR</code> is
the type of relationship it is referring to.</p>
</div>
<div class="paragraph">
<p>Two nodes can be connected with more than one relationships.</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)-[d:DIRECTED]-(m:Movie)
WHERE m.released > 2010
RETURN p,d,m<!--/code--></pre>
</div>
</div>
<div style="background: #5CA6D9EE; padding: 12px; color: white; border-radius: 2px">
Hint: You can click on the query above to populate it in the editor.
</div>
<div class="paragraph">
<p><strong>Expected Result</strong>: The above query will return all Person nodes who directed a movie that was released after 2010.</p>
</div>
<div class="imageblock">
<div class="content">
<img src="https://guides.neo4j.com/sandbox/movies/img/movies-after-2010.svg" alt="movies after 2010" width="100%">
</div>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Query to get all the people who acted in a movie that was released after 2010.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)-[r:ACTED_IN]-(m:Movie)
WHERE m.released > 2010
RETURN p,r,m<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Labels</h3>
<br/>
<div>
<div class="paragraph">
<p>Labels is a name or identifier of a Node or a Relationship. In the image below <code>Movie</code> and <code>Person</code> are Node labels and <code>ACTED_IN</code>, <code>REVIEWED</code>, etc are Relationship types.</p>
</div>
<div class="imageblock">
<div class="content">
<img src="https://guides.neo4j.com/sandbox/movies/img/schema.svg" alt="schema" width="100%">
</div>
</div>
<div class="paragraph">
<p>In writing a Cypher query, Labels are prefixed with a colon - like <code>:Person</code> or <code>:ACTED_IN</code>. You can assign the node label to a variable by prefixing the syntax with the variable name. Like <code>(p:Person)</code> means <code>p</code> variable denoted <code>Person</code> labeled nodes.</p>
</div>
<div class="paragraph">
<p>Labels are used when you want to perform operations only on a specific types of Nodes. Like</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)
RETURN p
LIMIT 20<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>will return only <code>Person</code> Nodes (limiting to 20 items) while</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (n)
RETURN n
LIMIT 20<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>will return all kinds of nodes (limiting to 20 items).</p>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Properties</h3>
<br/>
<div>
<div class="paragraph">
<p>Properties are name-value pairs that are used to add attributes to nodes and relationships.</p>
</div>
<div class="paragraph">
<p>To return specific properties of a node you can write</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie)
RETURN m.title, m.released<!--/code--></pre>
</div>
</div>
<div class="imageblock">
<div class="content">
<img src="https://guides.neo4j.com/sandbox/movies/img/movies-properties.jpg" alt="movies properties" width="100%">
</div>
</div>
<div class="paragraph">
<p><strong>Expected Result</strong> - This will return Movie nodes but with only the <code>title</code> and <code>released</code> properties.</p>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Write a query to get <code>name</code> and <code>born</code> properties of the Person node.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)
RETURN p.name, p.born<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Create a Node</h3>
<br/>
<div>
<div class="paragraph">
<p><code>CREATE</code> clause can be used to create a new node or a relationship.</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->CREATE (p:Person {name: 'John Doe'})
RETURN p<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>The above statement will create a new <code>Person</code> node with property <code>name</code> having value <code>John Doe</code>.</p>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Create a new <code>Person</code> node with a property <code>name</code> having the value of your name.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->CREATE (p:Person {name: '<Your Name>'})
RETURN p<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Finding Nodes with <strong>Match</strong> and <strong>Where</strong> Clause</h3>
<br/>
<div>
<div class="paragraph">
<p><code>Match</code> clause is used to find nodes that match a particular pattern. This is the primary way of getting data from a Neo4j database.</p>
</div>
<div class="paragraph">
<p>In most cases, a <code>Match</code> is used along with certain conditions to narrow down the result.</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person {name: 'Tom Hanks'})
RETURN p<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>This is one way of doing it. Although you can only do basic string match based filtering this way (without using <code>WHERE</code> clause).</p>
</div>
<div class="paragraph">
<p>Another way would be to use a <code>WHERE</code> clause which allows for more complex filtering including <code>></code>, <code><</code>, <code>STARTS WITH</code>, <code>ENDS WITH</code>, etc</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)
WHERE p.name = "Tom Hanks"
RETURN p<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>Both of the above queries will return the same results.</p>
</div>
<div class="paragraph">
<p>You can read more about Where clause and list of all filters here - <a href="https://neo4j.com/docs/cypher-manual/current/clauses/where/" class="bare">https://neo4j.com/docs/cypher-manual/current/clauses/where/</a></p>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Find the movie with title "Cloud Atlas"</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie {title: "Cloud Atlas"})
RETURN m<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
<li>
<p>Get all the movies that were released between 2010 and 2015.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie)
WHERE m.released > 2010 AND m.released < 2015
RETURN m<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Merge Clause</h3>
<br/>
<div>
<div class="paragraph">
<p>The <code>MERGE</code> clause is used to either</p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>match the existing nodes and bind them or</p>
</li>
<li>
<p>create new node(s) and bind them</p>
</li>
</ol>
</div>
<div class="paragraph">
<p>It is a combination of <code>MATCH</code> and <code>CREATE</code> and additionally allows to specify additional actions if the data was matched or created.</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MERGE (p:Person {name: 'John Doe'})
ON CREATE SET p.createdAt = timestamp()
ON MATCH SET p.lastLoggedInAt = timestamp()
RETURN p<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>The above statement will create the Person node if it does not exist. If the node already exists, then it will set the property <code>lastLoggedInAt</code> to the current timestamp. If the node did not exist and was newly created instead, then it will set the <code>createdAt</code> property to the current timestamp.</p>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Write a query using Merge to create a movie node with title "Greyhound". If the node does not exist then set its <code>released</code> property to 2020 and <code>lastUpdatedAt</code> property to the current time stamp. If the node already exists, then only set <code>lastUpdatedAt</code> to the current time stamp. Return the movie node.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MERGE (m:Movie {title: 'Greyhound'})
ON CREATE SET m.released = "2020", m.lastUpdatedAt = timestamp()
ON MATCH SET m.lastUpdatedAt = timestamp()
RETURN m<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Create a Relationship</h3>
<br/>
<div>
<div class="paragraph">
<p>A Relationship connects 2 nodes.</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person), (m:Movie)
WHERE p.name = "Tom Hanks" AND m.title = "Cloud Atlas"
CREATE (p)-[w:WATCHED]->(m)
RETURN type(w)<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>The above statement will create a relationship <code>:WATCHED</code> between the existing <code>Person</code> and <code>Movie</code> nodes and return the type of relationship (i.e <code>WATCHED</code>).</p>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Create a relationship <code>:WATCHED</code> between the node you created for yourself previously in step 6 and the movie <strong>Cloud Atlas</strong> and then return the type of created relationship</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person), (m:Movie)
WHERE p.name = "<Your Name>" AND m.title = "Cloud Atlas"
CREATE (p)-[w:WATCHED]->(m)
RETURN type(w)<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Relationship Types</h3>
<br/>
<div>
<div class="paragraph">
<p>In Neo4j, there can be 2 kinds of relationships - <strong>incoming</strong> and <strong>outgoing</strong>.</p>
</div>
<div class="imageblock">
<div class="content">
<img src="https://guides.neo4j.com/sandbox/movies/img/relationship-types.svg" alt="relationship types" width="400">
</div>
</div>
<div class="paragraph">
<p>In the above picture, the Tom Hanks node is said to have an outgoing relationship while the Cloud Atlas node is said to have an incoming relationship.</p>
</div>
<div class="paragraph">
<p>Relationships always have a direction. However, you only have to pay attention to the direction where it is useful.</p>
</div>
<div class="paragraph">
<p>To denote an outgoing or an incoming relationship in cypher, we use <code>→</code> or <code>←</code>.</p>
</div>
<div class="paragraph">
<p>Example -</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)-[r:ACTED_IN]->(m:Movie)
RETURN p,r,m<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>In the above query, Person has an outgoing relationship and movie has an incoming relationship.</p>
</div>
<div class="paragraph">
<p>Although, in the case of the movies dataset, the direction of the relationship is not that important and
even without denoting the direction in the query, it will return the same result. So the query</p>
</div>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)-[r:ACTED_IN]-(m:Movie)
RETURN p,r,m<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>will return the same reuslt as the above one.</p>
</div>
<div class="paragraph">
<p><strong>Try</strong></p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p>Write a query to find the nodes <code>Person</code> and <code>Movie</code> which are connected by <code>REVIEWED</code> relationship and is outgoing from the <code>Person</code> node and incoming to the <code>Movie</code> node.</p>
<div class="exampleblock">
<div class="content">
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)-[r:REVIEWED]-(m:Movie)
RETURN p,r,m<!--/code--></pre>
</div>
</div>
</div>
</div>
</li>
</ol>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Advanced Cypher queries</h3>
<br/>
<div>
<div class="paragraph">
<p>Let’s look at some questions that you can answer with Cypher queries.</p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p><strong>Finding who directed Cloud Atlas movie</strong></p>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (m:Movie {title: 'Cloud Atlas'})<-[d:DIRECTED]-(p:Person)
RETURN p.name<!--/code--></pre>
</div>
</div>
</li>
<li>
<p><strong>Finding all people who have co-acted with Tom Hanks in any movie</strong></p>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (tom:Person {name: "Tom Hanks"})-[:ACTED_IN]->(:Movie)<-[:ACTED_IN]-(p:Person)
RETURN p.name<!--/code--></pre>
</div>
</div>
</li>
<li>
<p><strong>Finding all people related to the movie Cloud Atlas in any way</strong></p>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person)-[relatedTo]-(m:Movie {title: "Cloud Atlas"})
RETURN p.name, type(relatedTo)<!--/code--></pre>
</div>
</div>
<div class="paragraph">
<p>In the above query, we only used the variable <code>relatedTo</code> which will try to find all the relationships between any <code>Person</code> node and the movie node "Cloud Atlas"</p>
</div>
</li>
<li>
<p>Finding Movies and Actors that are 3 hops away from Kevin Bacon.</p>
<div class="listingblock">
<div class="content">
<pre mode="cypher" class="highlight pre-scrollable programlisting cm-s-neo code runnable standalone-example ng-binding" data-lang="cypher" lang="cypher"><!--code class="cypher language-cypher"-->MATCH (p:Person {name: 'Kevin Bacon'})-[*1..3]-(hollywood)
RETURN DISTINCT p, hollywood<!--/code--></pre>
</div>
</div>
</li>
</ol>
</div>
<div class="paragraph">
<p>Note: in the above query, <code>hollywood</code> refers to any node in the database (in this case <code>Person</code> and <code>Movie</code> nodes)</p>
</div>
</div>
</div>
</slide>
<slide class="row-fluid">
<div class="col-sm-12">
<h3>Great Job!</h3>
<br/>
<div>
<div class="paragraph">
<p>Now you know the basics of writing Cypher queries. You are on your way to becoming a graphista! Congratulations.</p>
</div>
<div class="paragraph">
<p>Feel free to play around with the data by writing more Cypher queries. If you want to learn more about Cypher,</p>
</div>
<div class="paragraph">
<p>you can use one of the below resources</p>
</div>
<div class="olist arabic">
<ol class="arabic">
<li>
<p><a href="https://neo4j.com/docs/cypher-manual/">Cypher Manual</a> - detailed manual on Cypher syntax</p>
</li>
<li>
<p><a href="https://graphacademy.neo4j.com/">Online Training - Introduction to Neo4j</a> - If you are new to Neo4j and like to learn through an online class, this is the best place to get started.</p>
</li>
</ol>
</div>
</div>
</div>
</slide>
</carousel>
</article>