 
                        
        
                        
        org.neo4j.graphdb.Node Maven / Gradle / Ivy
Show all versions of neo4j-graphdb-api Show documentation
/*
 * Copyright (c) 2002-2016 "Neo Technology,"
 * Network Engine for Objects in Lund AB [http://neotechnology.com]
 *
 * This file is part of Neo4j.
 *
 * Neo4j is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see 
 * Node has three major groups of operations: operations that deal with
 * relationships, operations that deal with properties (see
 * {@link PropertyContainer}) and operations that deal with {@link Label labels}.
 * 
 * The relationship operations provide a number of overloaded accessors (such as
 * getRelationships(...) with "filters" for type, direction, etc),
 * as well as the factory method {@link #createRelationshipTo
 * createRelationshipTo(...)} that connects two nodes with a relationship. It
 * also includes the convenience method {@link #getSingleRelationship
 * getSingleRelationship(...)} for accessing the commonly occurring
 * one-to-zero-or-one association.
 * 
 * The property operations give access to the key-value property pairs. Property
 * keys are always strings. Valid property value types are all the Java
 * primitives (int, byte, float, etc),
 * java.lang.Strings and arrays of primitives and Strings.
 * 
 * Please note that Neo4j does NOT accept arbitrary objects as property
 * values. {@link #setProperty(String, Object) setProperty()} takes a
 * java.lang.Object only to avoid an explosion of overloaded
 * setProperty() methods. For further documentation see
 * {@link PropertyContainer}.
 * 
 * A node's id is unique, but note the following: Neo4j reuses its internal ids
 * when nodes and relationships are deleted, which means it's bad practice to
 * refer to them this way. Instead, use application generated ids.
 */
public interface Node extends PropertyContainer
{
    /**
     * Returns the unique id of this node. Ids are garbage collected over time
     * so they are only guaranteed to be unique during a specific time span: if
     * the node is deleted, it's likely that a new node at some point will get
     * the old id. Note: this makes node ids brittle as public APIs.
     *
     * @return the id of this node
     */
    long getId();
    /**
     * Deletes this node if it has no relationships attached to it. If
     * delete() is invoked on a node with relationships, an
     * unchecked exception will be raised when the transaction is committing.
     * Invoking any methods on this node after delete() has
     * returned is invalid and will lead to {@link NotFoundException} being thrown.
     */
    void delete();
    /**
     * Returns all the relationships attached to this node. If no relationships
     * are attached to this node, an empty iterable will be returned.
     *
     * @return all relationships attached to this node
     */
    Iterable getRelationships();
    /**
     * Returns true if there are any relationships attached to this
     * node, false otherwise.
     *
     * @return true if there are any relationships attached to this
     *         node, false otherwise
     */
    boolean hasRelationship();
    /**
     * Returns all the relationships of any of the types in types
     * that are attached to this node, regardless of direction. If no
     * relationships of the given types are attached to this node, an empty
     * iterable will be returned.
     *
     * @param types the given relationship type(s)
     * @return all relationships of the given type(s) that are attached to this
     *         node
     */
    Iterable getRelationships( RelationshipType... types );
    /**
     * Returns all the relationships of any of the types in types
     * that are attached to this node and have the given direction.
     * If no relationships of the given types are attached to this node, an empty
     * iterable will be returned.
     *
     * @param types the given relationship type(s)
     * @param direction the direction of the relationships to return.
     * @return all relationships of the given type(s) that are attached to this
     *         node
     */
    Iterable getRelationships( Direction direction, RelationshipType... types );
    /**
     * Returns true if there are any relationships of any of the
     * types in types attached to this node (regardless of
     * direction), false otherwise.
     *
     * @param types the given relationship type(s)
     * @return true if there are any relationships of any of the
     *         types in types attached to this node,
     *         false otherwise
     */
    boolean hasRelationship( RelationshipType... types );
    /**
     * Returns true if there are any relationships of any of the
     * types in types attached to this node (for the given
     * direction), false otherwise.
     *
     * @param types the given relationship type(s)
     * @param direction the direction to check relationships for
     * @return true if there are any relationships of any of the
     *         types in types attached to this node,
     *         false otherwise
     */
    boolean hasRelationship( Direction direction, RelationshipType... types );
    /**
     * Returns all {@link Direction#OUTGOING OUTGOING} or
     * {@link Direction#INCOMING INCOMING} relationships from this node. If
     * there are no relationships with the given direction attached to this
     * node, an empty iterable will be returned. If {@link Direction#BOTH BOTH}
     * is passed in as a direction, relationships of both directions are
     * returned (effectively turning this into getRelationships()).
     *
     * @param dir the given direction, where Direction.OUTGOING
     *            means all relationships that have this node as
     *            {@link Relationship#getStartNode() start node} and 
     * Direction.INCOMING
     *            means all relationships that have this node as
     *            {@link Relationship#getEndNode() end node}
     * @return all relationships with the given direction that are attached to
     *         this node
     */
    Iterable getRelationships( Direction dir );
    /**
     * Returns true if there are any relationships in the given
     * direction attached to this node, false otherwise. If
     * {@link Direction#BOTH BOTH} is passed in as a direction, relationships of
     * both directions are matched (effectively turning this into
     * hasRelationships()).
     *
     * @param dir the given direction, where Direction.OUTGOING
     *            means all relationships that have this node as
     *            {@link Relationship#getStartNode() start node} and 
     * Direction.INCOMING
     *            means all relationships that have this node as
     *            {@link Relationship#getEndNode() end node}
     * @return true if there are any relationships in the given
     *         direction attached to this node, false otherwise
     */
    boolean hasRelationship( Direction dir );
    /**
     * Returns all relationships with the given type and direction that are
     * attached to this node. If there are no matching relationships, an empty
     * iterable will be returned.
     *
     * @param type the given type
     * @param dir the given direction, where Direction.OUTGOING
     *            means all relationships that have this node as
     *            {@link Relationship#getStartNode() start node} and 
     * Direction.INCOMING
     *            means all relationships that have this node as
     *            {@link Relationship#getEndNode() end node}
     * @return all relationships attached to this node that match the given type
     *         and direction
     */
    Iterable getRelationships( RelationshipType type, Direction dir );
    /**
     * Returns true if there are any relationships of the given
     * relationship type and direction attached to this node, false
     * otherwise.
     *
     * @param type the given type
     * @param dir the given direction, where Direction.OUTGOING
     *            means all relationships that have this node as
     *            {@link Relationship#getStartNode() start node} and 
     * Direction.INCOMING
     *            means all relationships that have this node as
     *            {@link Relationship#getEndNode() end node}
     * @return true if there are any relationships of the given
     *         relationship type and direction attached to this node,
     *         false otherwise
     */
    boolean hasRelationship( RelationshipType type, Direction dir );
    /**
     * Returns the only relationship of a given type and direction that is
     * attached to this node, or null. This is a convenience method
     * that is used in the commonly occuring situation where a node has exactly
     * zero or one relationships of a given type and direction to another node.
     * Typically this invariant is maintained by the rest of the code: if at any
     * time more than one such relationships exist, it is a fatal error that
     * should generate an unchecked exception. This method reflects that
     * semantics and returns either:
     * 
     * - nullif there are zero relationships of the given type
     * and direction,
*- the relationship if there's exactly one, or
     * 
- throws an unchecked exception in all other cases.*
*
     * This method should be used only in situations with an invariant as
     * described above. In those situations, a "state-checking" method (e.g.
     * hasSingleRelationship(...)) is not required, because this
     * method behaves correctly "out of the box."
     *
     * @param type the type of the wanted relationship
     * @param dir the direction of the wanted relationship (where
     *            Direction.OUTGOING means a relationship that has
     *            this node as {@link Relationship#getStartNode() start node}
     *            and 
     * Direction.INCOMING means a relationship that has
     *            this node as {@link Relationship#getEndNode() end node}) or
     *            {@link Direction#BOTH} if direction is irrelevant
     * @return the single relationship matching the given type and direction if
     *         exactly one such relationship exists, or null if
     *         exactly zero such relationships exists
     * @throws RuntimeException if more than one relationship matches the given
     *             type and direction
     */
    Relationship getSingleRelationship( RelationshipType type, Direction dir );
    /**
     * Creates a relationship between this node and another node. The
     * relationship is of type type. It starts at this node and
     * ends at otherNode.
     * 
     * A relationship is equally well traversed in both directions so there's no
     * need to create another relationship in the opposite direction (in regards
     * to traversal or performance).
     *
     * @param otherNode the end node of the new relationship
     * @param type the type of the new relationship
     * @return the newly created relationship
     */
    Relationship createRelationshipTo( Node otherNode, RelationshipType type );
    /**
     * Returns relationship types which this node has one more relationships
     * for. If this node doesn't have any relationships an empty {@link Iterable}
     * will be returned.
     * @return relationship types which this node has one more relationships for.
     */
    public Iterable getRelationshipTypes();
    /**
     * Returns the number of relationships connected to this node regardless of
     * direction or type. This operation is always O(1).
     * @return the number of relationships connected to this node.
     */
    public int getDegree();
    /**
     * Returns the number of relationships of a given {@code type} connected to this node.
     *
     * @param type the type of relationships to get the degree for
     * @return the number of relationships of a given {@code type} connected to this node.
     */
    public int getDegree( RelationshipType type );
    /**
     * Returns the number of relationships of a given {@code direction} connected to this node.
     *
     * @param direction the direction of the relationships
     * @return the number of relationships of a given {@code direction} for this node.
     */
    public int getDegree( Direction direction );
    /**
     * Returns the number of relationships of a given {@code type} and {@code direction}
     * connected to this node.
     *
     * @param type the type of relationships to get the degree for
     * @param direction the direction of the relationships
     * @return the number of relationships of a given {@code type} and {@code direction}
     * for this node.
     */
    public int getDegree( RelationshipType type, Direction direction );
    /**
     * Adds a {@link Label} to this node. If this node doesn't already have
     * this label it will be added. If it already has the label, nothing will happen.
     *
     * @param label the label to add to this node.
     */
    void addLabel( Label label );
    /**
     * Removes a {@link Label} from this node. If this node doesn't have this label,
     * nothing will happen.
     *
     * @param label the label to remove from this node.
     */
    void removeLabel( Label label );
    /**
     * Checks whether or not this node has the given label.
     *
     * @param label the label to check for.
     * @return {@code true} if this node has the given label, otherwise {@code false}.
     */
    boolean hasLabel( Label label );
    /**
     * Lists all labels attached to this node. If this node has no
     * labels an empty {@link Iterable} will be returned.
     *
     * @return all labels attached to this node.
     */
    Iterable