Edges, Identifiers, Handles

This is an introduction to ArangoDB’s interface for edges.Edges may be used in graphs.Here we work with edges from the JavaScript shell arangosh.For other languages see the corresponding language API.

A graph data model always consists of at least two collections: the relations between thenodes in the graphs are stored in an “edges collection”, the nodes in the graphare stored in documents in regular collections.

Edges in ArangoDB are special documents. In addition to the systemattributes key_, id and __rev, they have the attributes from_ and to_, which contain document handles, namely the start-point and the end-point of the edge.

Example:

  • the “edge” collection stores the information that a company’s reception is sub-unit to the services unit and the services unit is sub-unit to theCEO. You would express this relationship with the from_ and to_ attributes
  • the “normal” collection stores all the properties about the reception, e.g. that 20 people are working there and the room number etc
  • _from is the document handle of the linked vertex (incoming relation)
  • _to is the document handle of the linked vertex (outgoing relation)Edge collections are special collections that store edge documents. Edge documents are connection documents that reference other documents. The type of a collection must be specified when a collection is created and cannot be changed afterwards.

To change edge endpoints you would need to remove old document/edge and insert new one.Other fields can be updated as in default collection.

Working with Edges

Edges are normal documentsthat always contain a _from and a _to attribute.