org.neo4j.driver.v1.StatementResult Maven / Gradle / Ivy
/*
* Copyright (c) 2002-2017 "Neo Technology,"
* Network Engine for Objects in Lund AB [http://neotechnology.com]
*
* This file is part of Neo4j.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.neo4j.driver.v1;
import java.util.Iterator;
import java.util.List;
import org.neo4j.driver.v1.exceptions.NoSuchRecordException;
import org.neo4j.driver.v1.summary.ResultSummary;
import org.neo4j.driver.v1.util.Function;
import org.neo4j.driver.v1.util.Resource;
/**
* The result of running a Cypher statement, conceptually a stream of {@link Record records}.
*
* The standard way of navigating through the result returned by the database is to
* {@link #next() iterate} over it.
*
* Results are valid until the next statement is run or until the end of the current transaction,
* whichever comes first. To keep a result around while further statements are run, or to use a result outside the scope
* of the current transaction, see {@link #list()}.
*
* Important note on semantics
*
* In order to handle very large results, and to minimize memory overhead and maximize
* performance, results are retrieved lazily. Please see {@link StatementRunner} for
* important details on the effects of this.
*
* The short version is that, if you want a hard guarantee that the underlying statement
* has completed, you need to either call {@link Resource#close()} on the {@link Transaction}
* or {@link Session} that created this result, or you need to use the result.
*
* Calling any method on this interface will guarantee that any write operation has completed on
* the remote database.
*
* @since 1.0
*/
public interface StatementResult extends Iterator
{
/**
* Retrieve the keys of the records this result contains.
*
* @return all keys
*/
List keys();
/**
* Test if there is another record we can navigate to in this result.
* @return true if {@link #next()} will return another record
*/
@Override boolean hasNext();
/**
* Navigate to and retrieve the next {@link Record} in this result.
*
* @throws NoSuchRecordException if there is no record left in the stream
* @return the next record
*/
@Override Record next();
/**
* Return the first record in the result, failing if there is not exactly
* one record left in the stream
*
* Calling this method always exhausts the result, even when {@link NoSuchRecordException} is thrown.
*
* @return the first and only record in the stream
* @throws NoSuchRecordException if there is not exactly one record left in the stream
*/
Record single() throws NoSuchRecordException;
/**
* Investigate the next upcoming record without moving forward in the result.
*
* @throws NoSuchRecordException if there is no record left in the stream
* @return the next record
*/
Record peek();
/**
* Retrieve and store the entire result stream.
* This can be used if you want to iterate over the stream multiple times or to store the
* whole result for later use.
*
* Note that this method can only be used if you know that the statement that
* yielded this result returns a finite stream. Some statements can yield
* infinite results, in which case calling this method will lead to running
* out of memory.
*
* Calling this method exhausts the result.
*
* @return list of all remaining immutable records
*/
List list();
/**
* Retrieve and store a projection of the entire result.
* This can be used if you want to iterate over the stream multiple times or to store the
* whole result for later use.
*
* Note that this method can only be used if you know that the statement that
* yielded this result returns a finite stream. Some statements can yield
* infinite results, in which case calling this method will lead to running
* out of memory.
*
* Calling this method exhausts the result.
*
* @param mapFunction a function to map from Record to T. See {@link Records} for some predefined functions.
* @param the type of result list elements
* @return list of all mapped remaining immutable records
*/
List list( Function mapFunction );
/**
* Consume the entire result, yielding a summary of it.
*
* Calling this method exhausts the result.
*
*
* {@code
* ResultSummary summary = session.run( "PROFILE MATCH (n:User {id: 12345}) RETURN n" ).consume();
* }
*
*
* @return a summary for the whole query result
*/
ResultSummary consume();
/**
* Return the result summary.
*
* If the records in the result is not fully consumed, then calling this method will force to pull all remaining
* records into buffer to yield the summary.
*
* If you want to obtain the summary but discard the records, use
* {@link StatementResult#consume()} instead.
*
* @return a summary for the whole query result.
*/
ResultSummary summary();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy