-
Notifications
You must be signed in to change notification settings - Fork 137
Indexes
In a graph database, a index is used as a way to quickly look up nodes and relationships. Entities can be indexed on any key/value pair. The key and value do not have to be properties on the entity.
It's important to note that indexes do not need to be created before they are used. The first time an entity is added to an index that does not exist, the index will be created on the server with a default configuration.
Indexes can be created independently of adding entities. The following code creates an index and then saves the index to the server.
$shipIndex = new Everyman\Neo4j\Index($client, Index::TypeNode, 'ships');
$shipIndex->save();
The Index::save()
operation will return true
if the index was successfully saved, and false
otherwise.
An index can be removed from the server, which will also remove any key/values that have been added to that index.
// Delete the ship index from the above example
$shipIndex->delete();
// Delete an index that had been created previously
$planetIndex = new Everyman\Neo4j\Index($client, Index::TypeNode, 'planets');
$planetIndex->delete();
The Index::delete()
operation will return true
if the index was successfully saved, and false
otherwise.
From the above example, you can see that instantiating an Index
object provides a reference to that index, even without saving it.
// These two objects reference the same index.
// Key/values added to one can be queried from the other.
$planetIndex = new Everyman\Neo4j\Index($client, Index::TypeNode, 'planets');
$otherIndex = new Everyman\Neo4j\Index($client, Index::TypeNode, 'planets');
The following code creates a node, then indexes the node on several key/values:
$shipIndex = new Everyman\Neo4j\Index($client, Index::TypeNode, 'ships');
$heartOfGold = new Everyman\Neo4j\Node($client);
$heartOfGold->setProperty('propulsion', 'infinite improbability drive')
->save();
// Index the ship on one of its properties
$shipIndex->add($heartOfGold, 'propulsion', $heartOfGold->getProperty('propulsion'));
// Index on arbitrary keys/values
$shipIndex->add($heartOfGold, 'captain', 'Zaphod');
$shipIndex->add($heartOfGold, 'computer', 'Eddie');
// Index an entity more than once on the same key
$shipIndex->add($heartOfGold, 'captain', 'Trillian');
Each Index::add()
operation will return true
if the entitiy was successfully indexed, and false
otherwise.
Entities do not have to be indexed on one of their properties. An entity can be indexed on any arbitrary key/value pair. The value must be a scalar (string or numeric) value.
An entity can be remove from an index on several levels: by specific a key/value pair; by all values for a key; and for all keys. The following code demonstrates each level:
// Remove node with a specific key/value
$shipIndex->remove($heartOfGold, 'computer', 'Eddie');
// Remove node for all values of a given key
$shipIndex->remove($heartOfGold, 'captain');
// Remove node for all keys/values
$shipIndex->remove($heartOfGold);
Each Index::remove()
operation will return true
if the entitiy was successfully removed, and false
otherwise.