Planner hints and the USING keyword
| Forcing planner behavior is an advanced feature, and should be used with caution by experienced developers and/or database administrators only, as it may cause queries to perform poorly. | 
Introduction
When executing a query, Neo4j needs to decide where in the query graph to start matching.
This is done by looking at the MATCH clause and the WHERE conditions and using that information to find useful indexes, or other starting points.
However, the selected index might not always be the best choice. Sometimes multiple indexes are possible candidates, and the query planner picks the suboptimal one from a performance point of view. Moreover, in some circumstances (albeit rarely) it is better not to use an index at all.
Neo4j can be forced to use a specific starting point through the USING keyword. This is called giving a planner hint.
There are four types of planner hints: index hints, scan hints, join hints, and the PERIODIC COMMIT query hint.
The following graph is used for the examples below:
  N0 [
    label = "{Scientist|name = \'Liskov\'\lborn = 1939\l}"
  ]
  N0 -> N2 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N0 -> N1 [
    color = "#4e9a06"
    fontcolor = "#4e9a06"
    label = "KNOWS\n"
  ]
  N1 [
    label = "{Scientist|name = \'Wing\'\lborn = 1956\l}"
  ]
  N1 -> N4 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N1 -> N2 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N2 [
    label = "{Science|name = \'Computer Science\'\l}"
  ]
  N3 [
    label = "{Scientist|name = \'Conway\'\lborn = 1938\l}"
  ]
  N3 -> N2 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N4 [
    label = "{Science|name = \'Engineering\'\l}"
  ]
  N5 [
    label = "{Science|name = \'Chemistry\'\l}"
  ]
  N6 [
    label = "{Scientist|name = \'Curie\'\lborn = 1867\l}"
  ]
  N6 -> N5 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N7 [
    label = "{Scientist|name = \'Arden\'\l}"
  ]
  N7 -> N5 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N8 [
    label = "{Scientist|name = \'Franklin\'\l}"
  ]
  N8 -> N5 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
  N9 [
    label = "{Scientist|name = \'Harrison\'\l}"
  ]
  N9 -> N5 [
    color = "#2e3436"
    fontcolor = "#2e3436"
    label = "RESEARCHED\n"
  ]
MATCH (liskov:Scientist {name:'Liskov'})-[:KNOWS]->(wing:Scientist)-[:RESEARCHED]->(cs:Science {name:'Computer Science'})<-[:RESEARCHED]-(conway:Scientist {name: 'Conway'}) RETURN 1 AS columnThe following query will be used in some of the examples on this page. It has intentionally been constructed in such a way that the statistical information will be inaccurate for the particular path that this query matches. For this reason, it can be improved by supplying planner hints.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| Operator                | Details                                                                                        | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Page Cache Hits/Misses | Time (ms) | Other               |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +ProduceResults         | column                                                                                         |              0 |    1 |       0 |                |                    0/0 |     0.056 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Projection             | $autoint_3 AS column                                                                           |              0 |    1 |       0 |                |                    0/0 |     0.031 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeHashJoin           | wing                                                                                           |              0 |    1 |       0 |            640 |                        |     0.600 | In Pipeline 5       |
| |\                      +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | not anon_122 = anon_68                                                                         |              0 |    2 |       0 |                |                    0/0 |     0.081 | In Pipeline 4       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeHashJoin         | cs                                                                                             |              0 |    3 |       0 |            768 |                    0/0 |     0.900 | In Pipeline 4       |
| | |\                    +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Expand(Into)       | (cs)<-[anon_122:RESEARCHED]-(conway)                                                           |              0 |    1 |       5 |            992 |                    0/0 |     0.257 | In Pipeline 3       |
| | | |                   +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +MultiNodeIndexSeek | cs:Science(name) WHERE name = $autostring_1, conway:Scientist(name) WHERE name = $autostring_2 |              0 |    1 |       4 |             72 |                    2/0 |     0.216 | In Pipeline 2       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | wing:Scientist                                                                                 |              0 |    3 |       3 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Expand(All)          | (cs)<-[anon_68:RESEARCHED]-(wing)                                                              |              0 |    3 |       4 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeIndexSeek        | cs:Science(name) WHERE name = $autostring_1                                                    |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 1 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Filter                 | wing:Scientist                                                                                 |              0 |    1 |       1 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Expand(All)            | (liskov)-[anon_41:KNOWS]->(wing)                                                               |              0 |    1 |       3 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeIndexSeek          | liskov:Scientist(name) WHERE name = $autostring_0                                              |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 0 |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
Total database accesses: 24, total allocated memory: 2168Index hints
Index hints are used to specify which index, if any, the planner should use as a starting point.
This can be beneficial in cases where the index statistics are not accurate for the specific values that
the query at hand is known to use, which would result in the planner picking a non-optimal index.
To supply an index hint, use USING INDEX variable:Label(property) or USING INDEX SEEK variable:Label(property) after the applicable MATCH clause.
It is possible to supply several index hints, but keep in mind that several starting points will require the use of a potentially expensive join later in the query plan.
Query using an index hint
The query above will not naturally pick an index to solve the plan. This is because the graph is very small, and label scans are faster for small databases. In general, however, query performance is ranked by the dbhit metric, and we see that using an index is slightly better for this query.
MATCH (liskov:Scientist {name:'Liskov'})-[:KNOWS]->(wing:Scientist)-[:RESEARCHED]->(cs:Science {name:'Computer Science'})<-[:RESEARCHED]-(conway:Scientist {name: 'Conway'}) USING INDEX liskov:Scientist(name) RETURN liskov.born AS columnReturns the year 'Barbara Liskov' was born.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| Operator                | Details                                                                                        | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Page Cache Hits/Misses | Time (ms) | Other               |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +ProduceResults         | column                                                                                         |              0 |    1 |       0 |                |                    0/0 |     0.055 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Projection             | liskov.born AS column                                                                          |              0 |    1 |       3 |                |                    1/0 |     0.097 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeHashJoin           | wing                                                                                           |              0 |    1 |       0 |            640 |                        |     0.036 | In Pipeline 5       |
| |\                      +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | not anon_122 = anon_68                                                                         |              0 |    2 |       0 |                |                    0/0 |     0.042 | In Pipeline 4       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeHashJoin         | cs                                                                                             |              0 |    3 |       0 |            768 |                    0/0 |     0.073 | In Pipeline 4       |
| | |\                    +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Expand(Into)       | (cs)<-[anon_122:RESEARCHED]-(conway)                                                           |              0 |    1 |       5 |            992 |                    0/0 |     0.182 | In Pipeline 3       |
| | | |                   +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +MultiNodeIndexSeek | cs:Science(name) WHERE name = $autostring_1, conway:Scientist(name) WHERE name = $autostring_2 |              0 |    1 |       4 |             72 |                    2/0 |     0.198 | In Pipeline 2       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | wing:Scientist                                                                                 |              0 |    3 |       3 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Expand(All)          | (cs)<-[anon_68:RESEARCHED]-(wing)                                                              |              0 |    3 |       4 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeIndexSeek        | cs:Science(name) WHERE name = $autostring_1                                                    |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 1 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Filter                 | wing:Scientist                                                                                 |              0 |    1 |       1 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Expand(All)            | (liskov)-[anon_41:KNOWS]->(wing)                                                               |              0 |    1 |       3 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeIndexSeek          | liskov:Scientist(name) WHERE name = $autostring_0                                              |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 0 |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
Total database accesses: 27, total allocated memory: 2168Query using an index seek hint
Similar to the index (scan) hint, but an index seek will be used rather than an index scan. Index seeks require no post filtering, they are most efficient when a relatively small number of nodes have the specified value on the queried property.
MATCH (liskov:Scientist {name:'Liskov'})-[:KNOWS]->(wing:Scientist)-[:RESEARCHED]->(cs:Science {name:'Computer Science'})<-[:RESEARCHED]-(conway:Scientist {name: 'Conway'}) USING INDEX SEEK liskov:Scientist(name) RETURN liskov.born AS columnReturns the year 'Barbara Liskov' was born.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| Operator                | Details                                                                                        | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Page Cache Hits/Misses | Time (ms) | Other               |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +ProduceResults         | column                                                                                         |              0 |    1 |       0 |                |                    0/0 |     0.050 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Projection             | liskov.born AS column                                                                          |              0 |    1 |       3 |                |                    1/0 |     0.105 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeHashJoin           | wing                                                                                           |              0 |    1 |       0 |            640 |                        |     0.044 | In Pipeline 5       |
| |\                      +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | not anon_122 = anon_68                                                                         |              0 |    2 |       0 |                |                    0/0 |     0.041 | In Pipeline 4       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeHashJoin         | cs                                                                                             |              0 |    3 |       0 |            768 |                    0/0 |     0.113 | In Pipeline 4       |
| | |\                    +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Expand(Into)       | (cs)<-[anon_122:RESEARCHED]-(conway)                                                           |              0 |    1 |       5 |            992 |                    0/0 |     0.101 | In Pipeline 3       |
| | | |                   +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +MultiNodeIndexSeek | cs:Science(name) WHERE name = $autostring_1, conway:Scientist(name) WHERE name = $autostring_2 |              0 |    1 |       4 |             72 |                    2/0 |     0.153 | In Pipeline 2       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | wing:Scientist                                                                                 |              0 |    3 |       3 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Expand(All)          | (cs)<-[anon_68:RESEARCHED]-(wing)                                                              |              0 |    3 |       4 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeIndexSeek        | cs:Science(name) WHERE name = $autostring_1                                                    |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 1 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Filter                 | wing:Scientist                                                                                 |              0 |    1 |       1 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Expand(All)            | (liskov)-[anon_41:KNOWS]->(wing)                                                               |              0 |    1 |       3 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeIndexSeek          | liskov:Scientist(name) WHERE name = $autostring_0                                              |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 0 |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
Total database accesses: 27, total allocated memory: 2168Query using multiple index hints
Supplying one index hint changed the starting point of the query, but the plan is still linear, meaning it only has one starting point. If we give the planner yet another index hint, we force it to use two starting points, one at each end of the match. It will then join these two branches using a join operator.
MATCH (liskov:Scientist {name:'Liskov'})-[:KNOWS]->(wing:Scientist)-[:RESEARCHED]->(cs:Science {name:'Computer Science'})<-[:RESEARCHED]-(conway:Scientist {name: 'Conway'}) USING INDEX liskov:Scientist(name) USING INDEX conway:Scientist(name) RETURN liskov.born AS columnReturns the year 'Barbara Liskov' was born, using a slightly better plan.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| Operator                | Details                                                                                        | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Page Cache Hits/Misses | Time (ms) | Other               |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +ProduceResults         | column                                                                                         |              0 |    1 |       0 |                |                    0/0 |     0.050 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Projection             | liskov.born AS column                                                                          |              0 |    1 |       3 |                |                    1/0 |     0.051 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeHashJoin           | wing                                                                                           |              0 |    1 |       0 |            640 |                        |     0.039 | In Pipeline 5       |
| |\                      +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | not anon_122 = anon_68                                                                         |              0 |    2 |       0 |                |                    0/0 |     0.044 | In Pipeline 4       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeHashJoin         | cs                                                                                             |              0 |    3 |       0 |            768 |                    0/0 |     0.113 | In Pipeline 4       |
| | |\                    +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Expand(Into)       | (cs)<-[anon_122:RESEARCHED]-(conway)                                                           |              0 |    1 |       5 |            992 |                    0/0 |     0.252 | In Pipeline 3       |
| | | |                   +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +MultiNodeIndexSeek | cs:Science(name) WHERE name = $autostring_1, conway:Scientist(name) WHERE name = $autostring_2 |              0 |    1 |       4 |             72 |                    2/0 |     0.181 | In Pipeline 2       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | wing:Scientist                                                                                 |              0 |    3 |       3 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Expand(All)          | (cs)<-[anon_68:RESEARCHED]-(wing)                                                              |              0 |    3 |       4 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeIndexSeek        | cs:Science(name) WHERE name = $autostring_1                                                    |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 1 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Filter                 | wing:Scientist                                                                                 |              0 |    1 |       1 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Expand(All)            | (liskov)-[anon_41:KNOWS]->(wing)                                                               |              0 |    1 |       3 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeIndexSeek          | liskov:Scientist(name) WHERE name = $autostring_0                                              |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 0 |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
Total database accesses: 27, total allocated memory: 2168Scan hints
If your query matches large parts of an index, it might be faster to scan the label and filter out nodes that do not match.
To do this, you can use USING SCAN variable:Label after the applicable MATCH clause.
This will force Cypher® to not use an index that could have been used, and instead do a label scan.
Hinting a label scan
If the best performance is to be had by scanning all nodes in a label and then filtering on that set, use USING SCAN.
MATCH (s:Scientist)
USING SCAN s:Scientist
WHERE s.born < 1939
RETURN s.born AS columnReturns all scientists born before '1939'.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+------------------+----------------------------+----------------+------+---------+----------------+---------------------+
| Operator         | Details                    | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Other               |
+------------------+----------------------------+----------------+------+---------+----------------+---------------------+
| +ProduceResults  | column                     |              3 |    2 |       0 |                | Fused in Pipeline 0 |
| |                +----------------------------+----------------+------+---------+----------------+---------------------+
| +Projection      | cache[s.born] AS column    |              3 |    2 |       0 |                | Fused in Pipeline 0 |
| |                +----------------------------+----------------+------+---------+----------------+---------------------+
| +Filter          | cache[s.born] < $autoint_0 |              3 |    2 |      18 |                | Fused in Pipeline 0 |
| |                +----------------------------+----------------+------+---------+----------------+---------------------+
| +NodeByLabelScan | s:Scientist                |             10 |    7 |       8 |             72 | Fused in Pipeline 0 |
+------------------+----------------------------+----------------+------+---------+----------------+---------------------+
Total database accesses: 26, total allocated memory: 72Join hints
Join hints are the most advanced type of hints, and are not used to find starting points for the query execution plan, but to enforce that joins are made at specified points. This implies that there has to be more than one starting point (leaf) in the plan, in order for the query to be able to join the two branches ascending from these leaves. Due to this nature, joins, and subsequently join hints, will force the planner to look for additional starting points, and in the case where there are no more good ones, potentially pick a very bad starting point. This will negatively affect query performance. In other cases, the hint might force the planner to pick a seemingly bad starting point, which in reality proves to be a very good one.
Hinting a join on a single node
In the example above using multiple index hints, we saw that the planner chose to do a join on the cs node.
This means that the relationship between wing and cs was traversed in the outgoing direction, which is better
statistically because the pattern ()-[:RESEARCHED]→(:Science) is more common than the pattern (:Scientist)-[:RESEARCHED]→().
However, in the actual graph, the cs node only has two such relationships, so expanding from it will be beneficial
to expanding from the wing node. We can force the join to happen on wing instead with a join hint.
MATCH (liskov:Scientist {name:'Liskov'})-[:KNOWS]->(wing:Scientist)-[:RESEARCHED]->(cs:Science {name:'Computer Science'})<-[:RESEARCHED]-(conway:Scientist {name: 'Conway'})
USING INDEX liskov:Scientist(name)
USING INDEX conway:Scientist(name)
USING JOIN ON wing
RETURN wing.born AS columnReturns the birth date of 'Jeanette Wing', using a slightly better plan.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| Operator                | Details                                                                                        | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Page Cache Hits/Misses | Time (ms) | Other               |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +ProduceResults         | column                                                                                         |              0 |    1 |       0 |                |                    0/0 |     0.051 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Projection             | wing.born AS column                                                                            |              0 |    1 |       3 |                |                    1/0 |     0.063 | In Pipeline 5       |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeHashJoin           | wing                                                                                           |              0 |    1 |       0 |            640 |                        |     0.045 | In Pipeline 5       |
| |\                      +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | not anon_122 = anon_68                                                                         |              0 |    2 |       0 |                |                    0/0 |     0.044 | In Pipeline 4       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeHashJoin         | cs                                                                                             |              0 |    3 |       0 |            768 |                    0/0 |     0.071 | In Pipeline 4       |
| | |\                    +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Expand(Into)       | (cs)<-[anon_122:RESEARCHED]-(conway)                                                           |              0 |    1 |       5 |            992 |                    0/0 |     0.080 | In Pipeline 3       |
| | | |                   +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +MultiNodeIndexSeek | cs:Science(name) WHERE name = $autostring_1, conway:Scientist(name) WHERE name = $autostring_2 |              0 |    1 |       4 |             72 |                    2/0 |     0.172 | In Pipeline 2       |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Filter               | wing:Scientist                                                                                 |              0 |    3 |       3 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Expand(All)          | (cs)<-[anon_68:RESEARCHED]-(wing)                                                              |              0 |    3 |       4 |                |                        |           | Fused in Pipeline 1 |
| | |                     +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeIndexSeek        | cs:Science(name) WHERE name = $autostring_1                                                    |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 1 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Filter                 | wing:Scientist                                                                                 |              0 |    1 |       1 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Expand(All)            | (liskov)-[anon_41:KNOWS]->(wing)                                                               |              0 |    1 |       3 |                |                        |           | Fused in Pipeline 0 |
| |                       +------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeIndexSeek          | liskov:Scientist(name) WHERE name = $autostring_0                                              |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 0 |
+-------------------------+------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
Total database accesses: 27, total allocated memory: 2168Hinting a join on multiple nodes
The query planner can be made to produce a join between several specific points. This requires the query to expand from the same node from several directions.
MATCH (liskov:Scientist {name:'Liskov'})-[:KNOWS]->(wing:Scientist {name:'Wing'})-[:RESEARCHED]->(cs:Science {name:'Computer Science'})<-[:RESEARCHED]-(liskov)
USING INDEX liskov:Scientist(name)
USING JOIN ON liskov, cs
RETURN wing.born AS columnReturns the birth date of 'Jeanette Wing'.
Compiler CYPHER 4.2
Planner COST
Runtime PIPELINED
Runtime version 4.2
+-----------------------+----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| Operator              | Details                                                                                            | Estimated Rows | Rows | DB Hits | Memory (Bytes) | Page Cache Hits/Misses | Time (ms) | Other               |
+-----------------------+----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +ProduceResults       | column                                                                                             |              0 |    1 |       0 |                |                    0/0 |     0.060 | In Pipeline 6       |
| |                     +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Projection           | wing.born AS column                                                                                |              0 |    1 |       3 |                |                    0/0 |     0.030 | In Pipeline 6       |
| |                     +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Filter               | not anon_136 = anon_82                                                                             |              0 |    1 |       0 |                |                    0/0 |     0.042 | In Pipeline 6       |
| |                     +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +NodeHashJoin         | cs, liskov                                                                                         |              0 |    1 |       0 |            720 |                    0/0 |     0.146 | In Pipeline 6       |
| |\                    +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +NodeHashJoin       | wing                                                                                               |              0 |    1 |       0 |            652 |                        |     0.080 | In Pipeline 5       |
| | |\                  +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Filter           | cache[cs.name] = $autostring_2 AND cs:Science                                                      |              0 |    1 |       5 |                |                        |           | Fused in Pipeline 4 |
| | | |                 +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +Expand(All)      | (wing)-[anon_82:RESEARCHED]->(cs)                                                                  |              0 |    2 |       4 |                |                        |           | Fused in Pipeline 4 |
| | | |                 +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | | +NodeIndexSeek    | wing:Scientist(name) WHERE name = $autostring_1                                                    |              0 |    1 |       2 |             72 |                        |           | Fused in Pipeline 4 |
| | |                   +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +Expand(Into)       | (liskov)-[anon_41:KNOWS]->(wing)                                                                   |              0 |    1 |       4 |            992 |                    0/0 |     0.089 | In Pipeline 3       |
| | |                   +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| | +MultiNodeIndexSeek | liskov:Scientist(name) WHERE name = $autostring_0, wing:Scientist(name) WHERE name = $autostring_1 |              0 |    1 |       4 |             72 |                    2/0 |     0.156 | In Pipeline 2       |
| |                     +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +Expand(Into)         | (cs)<-[anon_136:RESEARCHED]-(liskov)                                                               |              0 |    1 |       5 |            992 |                    2/0 |     0.125 | In Pipeline 1       |
| |                     +----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
| +MultiNodeIndexSeek   | cs:Science(name) WHERE name = $autostring_2, cache[cs.name],                                       |              0 |    1 |       4 |             72 |                    2/0 |     1.135 | In Pipeline 0       |
|                       | liskov:Scientist(name) WHERE name = $autostring_0, cache[cs.name]                                  |                |      |         |                |                        |           |                     |
+-----------------------+----------------------------------------------------------------------------------------------------+----------------+------+---------+----------------+------------------------+-----------+---------------------+
Total database accesses: 31, total allocated memory: 1956PERIODIC COMMIT query hint
Importing large amounts of data using LOAD CSV with a single Cypher query may fail due to memory constraints.
This will manifest itself as an OutOfMemoryError.
For this situation only, Cypher provides the global USING PERIODIC COMMIT query hint for updating queries using LOAD CSV.
If required, the limit for the number of rows per commit may be set as follows: USING PERIODIC COMMIT 500.
PERIODIC COMMIT will process the rows until the number of rows reaches a limit.
Then the current transaction will be committed and replaced with a newly opened transaction.
If no limit is set, a default value will be used.
See Importing large amounts of data in LOAD CSV for examples of USING PERIODIC COMMIT with and without setting the number of rows per commit.
| Using  | 
| The  |