# Change Log ## Future ### Bug Fixes * Fixed parsing of types for Python procedures for types nested in `mgp.List`. For example, parsing of `mgp.List[mgp.Map]` works now. * Fixed memory tracking issues. Some of the allocation and deallocation weren't tracked during the query execution. * Fixed reading CSV files that are using CRLF as the newline symbol. * Fixed permission issues for `LOAD CSV`, `FREE MEMORY`, `LOCK DATA DIRECTORY`, and replication queries. ## v1.4.0 ### Breaking Changes * Changed `MEMORY LIMIT num (KB|MB)` clause in the procedure calls to `PROCEDURE MEMORY LIMIT num (KB|MB)`. The functionality is still the same. ### Major Feature and Improvements * Added replication to community version. * Added support for multiple query modules directories at the same time. You can now define multiple, comma-separated paths to directories from which the modules will be loaded using the `--query-modules-directory` flag. * Added support for programatically reading in data from CSV files through the `LOAD CSV` clause. We support CSV files with and without a header, the supported dialect being Excel. * Added a new flag `--memory-limit` which enables the user to set the maximum total amount of memory memgraph can allocate during its runtime. * Added `FREE MEMORY` query which tries to free unusued memory chunks in different parts of storage. * Added the memory limit and amount of currently allocated bytes in the result of `SHOW STORAGE INFO` query. * Added `QUERY MEMORY LIMIT num (KB|MB)` to Cypher queries which allows you to limit memory allocation for the entire query. It can be added only at the end of the entire Cypher query. * Added logs for the different parts of the recovery process. `INFO`, `DEBUG` and `TRACE` level all contain additional information that is printed out while the recovery is in progress. ### Bug Fixes * Fixed garbage collector by correctly marking the oldest current timestamp after the database was recovered using the durability files. * Fixed reloading of the modules with changed result names. * Fixed profile query to show the correct name of the ScanAll operator variant. ## v1.3.0 ### Breaking Changes * Added extra information in durability files to support replication, making it incompatible with the durability files generated by older versions of Memgraph. Even though the replication is an Enterprise feature, the files are compatible with the Community version. ### Major Features and Improvements * Added support for data replication across a cluster of Memgraph instances. Supported instance types are MAIN and REPLICA. Supported replication modes are SYNC (all SYNC REPLICAS have to receive data before the MAIN can commit the transaction), ASYNC (MAIN doesn't care if data is replicated), SYNC WITH TIMEOUT (MAIN will wait for REPLICAS within the given timeout period, after timout, replication isn't aborted but the replication demotes the REPLICA to the ASYNC mode). * Added support for query type deduction. Possible query types are `r` (read), `w` (write), `rw` (read-write). The query type is returned as a part of the summary. * Improved logging capabilities by introducing granular logging levels. Added new flag, `--log-level`, which specifies the minimum log level that will be printed. E.g., it's possible to print incoming queries or Bolt server states. * Added ability to lock the storage data directory by executing the `LOCK DATA DIRECTORY;` query which delays the deletion of the files contained in the data directory. The data directory can be unlocked again by executing the `UNLOCK DATA DIRECTORY;` query. ### Bug Fixes and Other Changes * Added cleanup of query executions if not in an explicit transaction. * Fix RPC dangling reference. ## v1.2.0 ### Breaking Changes * SSL is disabled by default (`--bolt-cert-file` and `--bolt-key-file` are empty). This change might only affect the client connection configuration. ### Major Features and Improvements * Added support for Bolt v4.0 and v4.1. * Added `mgp_networkx.py` as an alternative implementation of NetworkX graph objects, which is useful to use Memgraph data from NetworkX algorithms optimally. * Added `nxalg.py` query module as a proxy to NetworkX algorithms. * Added plan optimization to use a label-property index where the property is not null. As a result, the query engine, instead of scanning all elements and applying the filter, performs a label-property index lookup when possible. ### Bug Fixes and Other Changes * Fixed Cypher `ID` function `Null` handling. When the `ID` function receives `Null`, it will also return `Null`. * Fixed bug that caused random crashes in SSL communication on platforms that use older versions of OpenSSL (< 1.1) by adding proper multi-threading handling. * Fix `DISCARD` message handling. The query is now executed before discarding the results. ## v1.1.0 ### Major Features and Improvements * Properties in nodes and edges are now stored encoded and compressed. This change significantly reduces memory usage. Depending on the specific dataset, total memory usage can be reduced up to 50%. * Added support for rescanning query modules. Previously, the query modules directory was scanned only upon startup. Now it is scanned each time the user requests to load a query module. The functions used to load the query modules were renamed to `mg.load()` and `mg.load_all()` (from `mg.reload()` and `mg.reload_all()`). * Improved execution performance of queries that have an IN list filter by using label+property indices. Example: `MATCH (n:Label) WHERE n.property IN [] ...` * Added support for `ANY` and `NONE` openCypher functions. Previously, only `ALL` and `SINGLE` functions were implemented. ### Bug Fixes and Other Changes * Fixed invalid paths returned by variable expansion when the starting node and destination node used the same symbol. Example: `MATCH path = (n:Person {name: "John"})-[:KNOWS*]->(n) RETURN path` * Improved semantics of `ALL` and `SINGLE` functions to be consistent with openCypher when handling lists with `Null`s. * `SHOW CONSTRAINT INFO` now returns property names as a list for unique constraints. * Escaped label/property/edgetype names in `DUMP DATABASE` to support names with spaces in them. * Fixed handling of `DUMP DATABASE` queries in multi-command transactions (`BEGIN`, ..., `COMMIT`). * Fixed handling of various query types in explicit transactions. For example, constraints were allowed to be created in multi-command transactions (`BEGIN`, ..., `COMMIT`) but that isn't a transactional operation and as such can't be allowed in multi-command transactions. * Fixed integer overflow bugs in `COUNT`, `LIMIT` and `SKIP`. * Fixed integer overflow bugs in weighted shortest path expansions. * Fixed various other integer overflow bugs in query execution. * Added Marvel Comic Universe tutorial. * Added FootballTransfers tutorial. ## v1.0.0 ### Major Features and Improvements * [Enterprise Ed.] Exposed authentication username/rolename regex as a flag (`--auth-user-or-role-name-regex`). * [Enterprise Ed.] Improved auth module error handling and added support for relative paths. * Added support for Python query modules. This release of Memgraph supports query modules written using the already existing C API and the new Python API. * Added support for unique constraints. The unique constraint is created with a label and one or more properties. * Implemented support for importing CSV files (`mg_import_csv`). The importer is compatible with the Neo4j batch CSV importer. * Snapshot and write-ahead log format changed (backward compatible with v0.50). * Vertices looked up by their openCypher ID (`MATCH (n) WHERE ID(n) = ...`) will now find the node in O(logn) instead of O(n). * Improved planning of BFS expansion, a faster, specific approach is now favored instead of a ScanAll+Filter operation. * Added syntax for limiting memory of `CALL`. * Exposed server name that should be used for Bolt handshake as flag (`--bolt-server-name-for-init`). * Added several more functions to the query module C API. * Implemented a storage locking mechanism that prevents the user from concurrently starting two Memgraph instances with the same data directory. ### Bug Fixes and Other Changes * [Enterprise Ed.] Fixed a bug that crashed the database when granting privileges to a user. * [Enterprise Ed.] Improved Louvain algorithm for community detection. * Type of variable expansion is now printed in `EXPLAIN` (e.g. ExpandVariable, STShortestPath, BFSExpand, WeightedShortestPath). * Correctly display `CALL` in `EXPLAIN` output. * Correctly delimit arguments when printing the signature of a query module. * Fixed a planning issue when `CALL` preceded filtering. * Fixed spelling mistakes in the storage durability module. * Fixed storage GC indices/constraints subtle race condition. * Reduced memory allocations in storage API and indices. * Memgraph version is now outputted to `stdout` when Memgraph is started. * Improved RPM packaging. * Reduced number of errors reported in production log when loading query modules. * Removed `early access` wording from the Community Offering license. ## v0.50.0 ### Breaking Changes * [Enterprise Ed.] Remove support for Kafka streams. * Snapshot and write-ahead log format changed (not backward compatible). * Removed support for unique constraints. * Label indices aren't created automatically, create them explicitly instead. * Renamed several database flags. Please see the configuration file for a list of current flags. ### Major Features and Improvements * [Enterprise Ed.] Add support for auth module. * [Enterprise Ed.] LDAP support migrated to auth module. * Implemented new graph storage engine. * Add support for disabling properties on edges. * Add support for existence constraints. * Add support for custom openCypher procedures using a C API. * Support loading query modules implementing read-only procedures. * Add `CALL YIELD ` syntax for invoking loaded procedures. * Add `CREATE INDEX ON :Label` for creating label indices. * Add `DROP INDEX ON :Label` for dropping label indices. * Add `DUMP DATABASE` clause to openCypher. * Add functions for treating character strings as byte strings. ### Bug Fixes and Other Changes * Fix several memory management bugs. * Reduce memory usage in query execution. * Fix bug that crashes the database when `EXPLAIN` is used. ## v0.15.0 ### Breaking Changes * Snapshot and write-ahead log format changed (not backward compatible). * `indexInfo()` function replaced with `SHOW INDEX INFO` syntax. * Removed support for unique index. Use unique constraints instead. * `CREATE UNIQUE INDEX ON :label (property)` replaced with `CREATE CONSTRAINT ON (n:label) ASSERT n.property IS UNIQUE`. * Changed semantics for `COUNTER` openCypher function. ### Major Features and Improvements * [Enterprise Ed.] Add new privilege, `STATS` for accessing storage info. * [Enterprise Ed.] LDAP authentication and authorization support. * [Enterprise Ed.] Add audit logging feature. * Add multiple properties unique constraint which replace unique indices. * Add `SHOW STORAGE INFO` feature. * Add `PROFILE` clause to openCypher. * Add `CREATE CONSTRAINT` clause to openCypher. * Add `DROP CONSTRAINT` clause to openCypher. * Add `SHOW CONSTRAINT INFO` feature. * Add `uniformSample` function to openCypher. * Add regex matching to openCypher. ### Bug Fixes and Other Changes * Fix bug in explicit transaction handling. * Fix bug in edge filtering by edge type and destination. * Fix bug in query comment parsing. * Fix bug in query symbol table. * Fix OpenSSL memory leaks. * Make authentication case insensitive. * Remove `COALESCE` function. * Add movie tutorial. * Add backpacking tutorial. ## v0.14.0 ### Breaking Changes * Write-ahead log format changed (not backward compatible). ### Major Features and Improvements * [Enterprise Ed.] Reduce memory usage in distributed usage. * Add `DROP INDEX` feature. * Improve SSL error messages. ### Bug Fixes and Other Changes * [Enterprise Ed.] Fix issues with reading and writing in a distributed query. * Correctly handle an edge case with unique constraint checks. * Fix a minor issue with `mg_import_csv`. * Fix an issue with `EXPLAIN`. ## v0.13.0 ### Breaking Changes * Write-ahead log format changed (not backward compatible). * Snapshot format changed (not backward compatible). ### Major Features and Improvements * [Enterprise Ed.] Authentication and authorization support. * [Enterprise Ed.] Kafka integration. * [Enterprise Ed.] Support dynamic worker addition in distributed. * Reduce memory usage and improve overall performance. * Add `CREATE UNIQUE INDEX` clause to openCypher. * Add `EXPLAIN` clause to openCypher. * Add `inDegree` and `outDegree` functions to openCypher. * Improve BFS performance when both endpoints are known. * Add new `node-label`, `relationship-type` and `quote` options to `mg_import_csv` tool. * Reduce memory usage of `mg_import_csv`. ### Bug Fixes and Other Changes * [Enterprise Ed.] Fix an edge case in distributed index creation. * [Enterprise Ed.] Fix issues with Cartesian in distributed queries. * Correctly handle large messages in Bolt protocol. * Fix issues when handling explicitly started transactions in queries. * Allow openCypher keywords to be used as variable names. * Revise and make user visible error messages consistent. * Improve aborting time consuming execution. ## v0.12.0 ### Breaking Changes * Snapshot format changed (not backward compatible). ### Major Features and Improvements * Improved Id Cypher function. * Added string functions to openCypher (`lTrim`, `left`, `rTrim`, `replace`, `reverse`, `right`, `split`, `substring`, `toLower`, `toUpper`, `trim`). * Added `timestamp` function to openCypher. * Added support for dynamic property access with `[]` operator. ## v0.11.0 ### Major Features and Improvements * [Enterprise Ed.] Improve Cartesian support in distributed queries. * [Enterprise Ed.] Improve distributed execution of BFS. * [Enterprise Ed.] Dynamic graph partitioner added. * Static nodes/edges id generators exposed through the Id Cypher function. * Properties on disk added. * Telemetry added. * SSL support added. * `toString` function added. ### Bug Fixes and Other Changes * Document issues with Docker on OS X. * Add BFS and Dijkstra's algorithm examples to documentation. ## v0.10.0 ### Breaking Changes * Snapshot format changed (not backward compatible). ### Major Features and Improvements * [Enterprise Ed.] Distributed storage and execution. * `reduce` and `single` functions added to openCypher. * `wShortest` edge expansion added to openCypher. * Support packaging RPM on CentOS 7. ### Bug Fixes and Other Changes * Report an error if updating a deleted element. * Log an error if reading info on available memory fails. * Fix a bug when `MATCH` would stop matching if a result was empty, but later results still contain data to be matched. The simplest case of this was the query: `UNWIND [1,2,3] AS x MATCH (n :Label {prop: x}) RETURN n`. If there was no node `(:Label {prop: 1})`, then the `MATCH` wouldn't even try to find for `x` being 2 or 3. * Report an error if trying to compare a property value with something that cannot be stored in a property. * Fix crashes in some obscure cases. * Commit log automatically garbage collected. * Add minor performance improvements. ## v0.9.0 ### Breaking Changes * Snapshot format changed (not backward compatible). * Snapshot configuration flags changed, general durability flags added. ### Major Features and Improvements * Write-ahead log added. * `nodes` and `relationships` functions added. * `UNION` and `UNION ALL` is implemented. * Concurrent index creation is now enabled. ### Bug Fixes and Other Changes ## v0.8.0 ### Major Features and Improvements * CASE construct (without aggregations). * Named path support added. * Maps can now be stored as node/edge properties. * Map indexing supported. * `rand` function added. * `assert` function added. * `counter` and `counterSet` functions added. * `indexInfo` function added. * `collect` aggregation now supports Map collection. * Changed the BFS syntax. ### Bug Fixes and Other Changes * Use \u to specify 4 digit codepoint and \U for 8 digit * Keywords appearing in header (named expressions) keep original case. * Our Bolt protocol implementation is now completely compatible with the protocol version 1 specification. (https://boltprotocol.org/v1/) * Added a log warning when running out of memory and the `memory_warning_threshold` flag * Edges are no longer additionally filtered after expansion. ## v0.7.0 ### Major Features and Improvements * Variable length path `MATCH`. * Explicitly started transactions (multi-query transactions). * Map literal. * Query parameters (except for parameters in place of property maps). * `all` function in openCypher. * `degree` function in openCypher. * User specified transaction execution timeout. ### Bug Fixes and Other Changes * Concurrent `BUILD INDEX` deadlock now returns an error to the client. * A `MATCH` preceeded by `OPTIONAL MATCH` expansion inconsistencies. * High concurrency Antlr parsing bug. * Indexing improvements. * Query stripping and caching speedups. ## v0.6.0 ### Major Features and Improvements * AST caching. * Label + property index support. * Different logging setup & format. ## v0.5.0 ### Major Features and Improvements * Use label indexes to speed up querying. * Generate multiple query plans and use the cost estimator to select the best. * Snapshots & Recovery. * Abandon old yaml configuration and migrate to gflags. * Query stripping & AST caching support. ### Bug Fixes and Other Changes * Fixed race condition in MVCC. Hints exp+aborted race condition prevented. * Fixed conceptual bug in MVCC GC. Evaluate old records w.r.t. the oldest. transaction's id AND snapshot. * User friendly error messages thrown from the query engine. ## Build 837 ### Bug Fixes and Other Changes * List indexing supported with preceeding IN (for example in query `RETURN 1 IN [[1,2]][0]`). ## Build 825 ### Major Features and Improvements * RETURN *, count(*), OPTIONAL MATCH, UNWIND, DISTINCT (except DISTINCT in aggregate functions), list indexing and slicing, escaped labels, IN LIST operator, range function. ### Bug Fixes and Other Changes * TCP_NODELAY -> import should be faster. * Clear hint bits. ## Build 783 ### Major Features and Improvements * SKIP, LIMIT, ORDER BY. * Math functions. * Initial support for MERGE clause. ### Bug Fixes and Other Changes * Unhandled Lock Timeout Exception. ## Build 755 ### Major Features and Improvements * MATCH, CREATE, WHERE, SET, REMOVE, DELETE.