2017-06-06 18:03:45 +08:00
|
|
|
## Upcoming Features
|
|
|
|
|
2017-06-09 19:39:01 +08:00
|
|
|
This chapter describes some of the planned features, that we at Memgraph are
|
|
|
|
working on.
|
|
|
|
|
|
|
|
### Performance Improvements
|
|
|
|
|
|
|
|
Excellent database performance is one of Memgraph's long-standing goals. We
|
|
|
|
will be continually working on improving the performance. This includes:
|
|
|
|
|
|
|
|
* query compilation;
|
|
|
|
* query execution;
|
|
|
|
* core engine performance;
|
2017-09-13 19:38:53 +08:00
|
|
|
* algorithmic improvements (i.e. bidirectional breadth-first search);
|
2017-06-09 19:39:01 +08:00
|
|
|
* memory usage and
|
|
|
|
* other improvements.
|
|
|
|
|
2017-07-12 16:23:42 +08:00
|
|
|
### Label-Property Index Usage Improvements
|
2017-06-09 19:39:01 +08:00
|
|
|
|
2017-07-12 16:23:42 +08:00
|
|
|
Currently, indexing combinations of labels and properties can be created, but
|
|
|
|
cannot be deleted. We plan to add a new query language construct which will
|
|
|
|
allow deletion of created indices.
|
2017-06-09 19:39:01 +08:00
|
|
|
|
2017-07-12 16:23:42 +08:00
|
|
|
### Improving openCypher Support
|
2017-06-09 19:39:01 +08:00
|
|
|
|
|
|
|
Although we have implemented the most common features of the openCypher query
|
|
|
|
language, there are other useful features we are still working on.
|
|
|
|
|
|
|
|
#### Named Paths
|
|
|
|
|
|
|
|
It would be useful to store paths that match a pattern into a variable. This
|
|
|
|
enables the user to display the matched patterns or do some other operations
|
|
|
|
on the path, like calculating the length of the path.
|
|
|
|
|
|
|
|
The feature would be used by simply assigning the variable to a pattern. For
|
|
|
|
example:
|
|
|
|
|
|
|
|
MATCH path = (node1) -[connection]-> (node2)
|
|
|
|
|
2017-07-26 16:07:59 +08:00
|
|
|
Path naming is especially useful with the *variable length paths* feature.
|
2017-06-09 19:39:01 +08:00
|
|
|
|
|
|
|
#### Functions
|
|
|
|
|
|
|
|
Memgraph's openCypher implementation supports the most useful functions, but
|
|
|
|
there are more which openCypher provides. Some are related to not yet
|
|
|
|
implemented features like paths, while some may use the features Memgraph
|
|
|
|
already supports. Out of the remaining functions, some are more useful than
|
|
|
|
others and as such they will be supported sooner.
|
|
|
|
|
|
|
|
#### UNION
|
|
|
|
|
|
|
|
The `UNION` clause will offer joining the results from multiple queries. For
|
|
|
|
example, finding names of `:Person` and `:Car` names.
|
|
|
|
|
|
|
|
MATCH (p :Person) RETURN p.name AS name
|
|
|
|
UNION
|
|
|
|
MATCH (c :Car) RETURN c.name AS name
|
|
|
|
|
|
|
|
#### List Comprehensions
|
|
|
|
|
|
|
|
List comprehensions are similar to the supported `collect` function, which
|
|
|
|
generates a list out of multiple values. But unlike `collect`, list
|
|
|
|
comprehensions offer a powerful mechanism for filtering or otherwise
|
|
|
|
manipulating values which are collected into a list.
|
|
|
|
|
|
|
|
For example, getting numbers between 0 and 10 and squaring them:
|
|
|
|
|
|
|
|
RETURN [x IN range(0, 10) | x^2] AS squares
|
|
|
|
|
|
|
|
Another example, to collect `:Person` nodes with `age` less than 42, without
|
|
|
|
list comprehensions can be achieved with:
|
|
|
|
|
|
|
|
MATCH (n :Person) WHERE n.age < 42 RETURN collect(n)
|
|
|
|
|
|
|
|
Using list comprehensions, the same can be done with the query:
|
|
|
|
|
|
|
|
MATCH (n :Person) RETURN [n IN collect(n) WHERE n.age < 42]
|
|
|
|
|