Fingerprinting
The following functions calculate hashsums over nodes, relationship or the entire graph. It takes into account all properties, node labels and relationship types.
The algorithm used for hashing may change between APOC versions. So we can only compare hashing results of two entities/graphs from the same or from different graph using the very same apoc version. |
The hashsum of a graph first calculates the hashsums for each node. This hashsum list is ordered and for each node the hashsum for all relationships and their end node are added. This approach provides independence of internal ids.
Optionally you can supply a list of propertyKeys
that should be ignored on all nodes.
This is useful if you store properties (like created=timestamp()
) that should be ignored.
function name | description |
---|---|
|
calculates a md5 hashsum over the object. It deals gracefully with ordering (in case of maps), scalars, arrays. Unsuitable for cryptographic use-cases. |
|
calculates a md5 hashsum over the object. It deals gracefully with ordering (in case of maps), scalars, arrays. Unsuitable for cryptographic use-cases. Please check the |
|
calculates a md5 hashsum over the full graph. Unsuitable for cryptographic use-cases. |
Configuration parameters
prop name | type | default | description |
---|---|---|---|
|
ENUM |
MD5 |
the digest algorithm used to create the fingerprint, we only support MD5 right now |
|
Map<K,V> |
empty |
a map where the key is the node Label and the value is a lists properties allowed |
|
Map<K,V> |
empty |
a map where the key is the rel type and the value is a lists properties allowed |
|
Map<K,V> |
empty |
a DisallowMap map where the key is the node Label and the value is a lists properties disallowed |
|
Map<K,V> |
empty |
a DisallowMap map where the key is the rel type and the value is a lists properties disallowed |
|
List |
empty |
a List used in case the input to the procedure is a map allowed |
|
List |
empty |
a List used in case the input to the procedure is a map disallowed |
|
List |
empty |
a List used for properties common to all Nodes that you need to include in the fingerprint |
|
List |
empty |
a List used for properties common to all Relationships that you need to include in the fingerprint |
|
List |
empty |
a List used for properties common to all Nodes that you need to exclude from the fingerprint |
|
List |
empty |
a List used for properties common to all Relationships that you need to exclude from the fingerprint |
|
Enum[EAGER, LAZY] |
LAZY |
define the behaviour in case the properties are not present for the specific node/relationship, see the |
Fingerprinting strategy
In case the properties defined in the configuration are not present in the node and/or relationship you can define how the fingerprinting procedure must proceed with the process:
-
EAGER
: it evaluates the whole node properties in order to create the fingerprint of the node/relationship -
LAZY
: it evaluates only the nodes/relationships provided in the configuration