OPTIONAL MATCH
Introduction
OPTIONAL MATCH matches patterns against your graph database, just like MATCH does.
The difference is that if no matches are found, OPTIONAL MATCH will use a null for missing parts of the pattern.
OPTIONAL MATCH could be considered the Cypher® equivalent of the outer join in SQL.
Either the whole pattern is matched, or nothing is matched.
Remember that WHERE is part of the pattern description, and the predicates will be considered while looking for matches, not after.
This matters especially in the case of multiple (OPTIONAL) MATCH clauses, where it is crucial to put WHERE together with the MATCH it belongs to.
| To understand the patterns used in the  | 
The following graph is used for the examples below:
  N0 [
    label = "{Person|name = \'Charlie Sheen\'\l}"
  ]
  N0 -> N1 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "FATHER\n"
  ]
  N0 -> N5 [
    color = "#4e9a06"
    fontcolor = "#4e9a06"
    label = "ACTED_IN\n"
  ]
  N1 [
    label = "{Person|name = \'Martin Sheen\'\l}"
  ]
  N1 -> N6 [
    color = "#4e9a06"
    fontcolor = "#4e9a06"
    label = "ACTED_IN\n"
  ]
  N1 -> N5 [
    color = "#4e9a06"
    fontcolor = "#4e9a06"
    label = "ACTED_IN\n"
  ]
  N2 [
    label = "{Person|name = \'Michael Douglas\'\l}"
  ]
  N2 -> N5 [
    color = "#4e9a06"
    fontcolor = "#4e9a06"
    label = "ACTED_IN\n"
  ]
  N2 -> N6 [
    color = "#4e9a06"
    fontcolor = "#4e9a06"
    label = "ACTED_IN\n"
  ]
  N3 [
    label = "{Person|name = \'Oliver Stone\'\l}"
  ]
  N3 -> N5 [
    color = "#a40000"
    fontcolor = "#a40000"
    label = "DIRECTED\n"
  ]
  N4 [
    label = "{Person|name = \'Rob Reiner\'\l}"
  ]
  N4 -> N6 [
    color = "#a40000"
    fontcolor = "#a40000"
    label = "DIRECTED\n"
  ]
  N5 [
    label = "{Movie|title = \'Wall Street\'\l}"
  ]
  N6 [
    label = "{Movie|title = \'The American President\'\l}"
  ]
Optional relationships
If a relationship is optional, use the OPTIONAL MATCH clause.
This is similar to how a SQL outer join works.
If the relationship is there, it is returned.
If it’s not, null is returned in its place.
MATCH (a:Movie {title: 'Wall Street'})
OPTIONAL MATCH (a)-->(x)
RETURN xReturns null, since the node has no outgoing relationships.
| x | 
|---|
| 
 | 
| Rows: 1 | 
Properties on optional elements
Returning a property from an optional element that is null will also return null.
MATCH (a:Movie {title: 'Wall Street'})
OPTIONAL MATCH (a)-->(x)
RETURN x, x.nameReturns the element x (null in this query), and null as its name.
| x | x.name | 
|---|---|
| 
 | 
 | 
| Rows: 1 | |
Optional typed and named relationship
Just as with a normal relationship, you can decide which variable it goes into, and what relationship type you need.
MATCH (a:Movie {title: 'Wall Street'})
OPTIONAL MATCH (a)-[r:ACTS_IN]->()
RETURN a.title, rThis returns the title of the node, 'Wall Street', and, since the node has no outgoing ACTS_IN relationships, null is returned for the relationship denoted by r.
| a.title | r | 
|---|---|
| 
 | 
 | 
| Rows: 1 | |