io.tarantool.driver.api.space.TarantoolSpaceOperations Maven / Gradle / Ivy
package io.tarantool.driver.api.space;
import io.tarantool.driver.api.conditions.Conditions;
import io.tarantool.driver.api.cursor.TarantoolCursor;
import io.tarantool.driver.api.metadata.TarantoolSpaceMetadata;
import io.tarantool.driver.api.space.options.DeleteOptions;
import io.tarantool.driver.api.space.options.InsertManyOptions;
import io.tarantool.driver.api.space.options.InsertOptions;
import io.tarantool.driver.api.space.options.ReplaceManyOptions;
import io.tarantool.driver.api.space.options.ReplaceOptions;
import io.tarantool.driver.api.space.options.SelectOptions;
import io.tarantool.driver.api.space.options.UpdateOptions;
import io.tarantool.driver.api.space.options.UpsertOptions;
import io.tarantool.driver.api.tuple.operations.TupleOperations;
import io.tarantool.driver.exceptions.TarantoolClientException;
import io.tarantool.driver.protocol.Packable;
import java.util.Collection;
import java.util.concurrent.CompletableFuture;
/**
* Tarantool space operations interface (create, insert, replace, delete...)
*
* @param tuple type
* @param tuple collection type
* @author Alexey Kuzin
*/
public interface TarantoolSpaceOperations> {
/**
* Delete a tuple. Only a single primary index value condition is supported.
*
* @param conditions query with options
* @return a future that will contain removed tuple once completed
* @throws TarantoolClientException in case if the request failed
*/
CompletableFuture delete(Conditions conditions) throws TarantoolClientException;
/**
* Delete a tuple. Only a single primary index value condition is supported.
*
* @param conditions query with options
* @param options operation options
* @return a future that will contain removed tuple once completed
* @throws TarantoolClientException in case if the request failed
*/
default CompletableFuture delete(Conditions conditions, DeleteOptions options) throws TarantoolClientException {
return delete(conditions);
}
/**
* Inserts tuple into the space, if no tuple with same unique keys exists. Otherwise throw duplicate key error.
*
* @param tuple new data
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
CompletableFuture insert(T tuple) throws TarantoolClientException;
/**
* Inserts tuple into the space, if no tuple with same unique keys exists. Otherwise throw duplicate key error.
*
* @param tuple new data
* @param options operation options
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
default CompletableFuture insert(T tuple, InsertOptions options) throws TarantoolClientException {
return insert(tuple);
}
/**
* Inserts several tuples into the space at once. If writing of any tuple fails,
* all tuples will not be saved.
*
* @param tuples new data
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
CompletableFuture insertMany(Collection tuples) throws TarantoolClientException;
/**
* Inserts several tuples into the space at once. If writing of any tuple fails,
* all tuples will not be saved.
*
* @param tuples new data
* @param options operation options
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
default CompletableFuture insertMany(Collection tuples, InsertManyOptions options)
throws TarantoolClientException {
return insertMany(tuples);
}
/**
* Insert a tuple into the space or replace an existing one.
*
* @param tuple new data
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
CompletableFuture replace(T tuple) throws TarantoolClientException;
/**
* Insert a tuple into the space or replace an existing one.
*
* @param tuple new data
* @param options operation options
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
default CompletableFuture replace(T tuple, ReplaceOptions options) throws TarantoolClientException {
return replace(tuple);
}
/**
* Insert or replace several tuples into the space at once. If writing of any tuple fails,
* all tuples will not be saved.
*
* @param tuples new data
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
CompletableFuture replaceMany(Collection tuples) throws TarantoolClientException;
/**
* Insert or replace several tuples into the space at once. If writing of any tuple fails,
* all tuples will not be saved, but this behavior can be changed with the options.
*
* @param tuples new data
* @param options operation options
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if request failed
*/
default CompletableFuture replaceMany(Collection tuples, ReplaceManyOptions options)
throws TarantoolClientException {
return replaceMany(tuples);
}
/**
* Select tuples matching the specified query with options.
*
* @param conditions query with options
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if the request failed
*/
CompletableFuture select(Conditions conditions) throws TarantoolClientException;
/**
* Select tuples matching the specified query with specified conditions and options.
*
* @param conditions specified conditions
* @param options operation options
* @return a future that will contain all corresponding tuples once completed
* @throws TarantoolClientException in case if the request failed
*/
default CompletableFuture select(Conditions conditions, SelectOptions options) throws TarantoolClientException {
return select(conditions);
}
/**
* Update a tuple. Only a single primary index value condition is supported.
*
* @param conditions query with options
* @param tuple tuple with new field values
* @return a future that will contain corresponding tuple once completed
* @throws TarantoolClientException in case if the request failed
*/
CompletableFuture update(Conditions conditions, T tuple);
/**
* Update a tuple. Only a single primary index value condition is supported.
*
* @param conditions query with options
* @param tuple tuple with new field values
* @param options operation options
* @return a future that will contain corresponding tuple once completed
* @throws TarantoolClientException in case if the request failed
*/
default CompletableFuture update(Conditions conditions, T tuple, UpdateOptions options) {
return update(conditions, tuple);
}
/**
* Update a tuple. Only a single primary index value condition is supported.
*
* @param conditions query with options
* @param operations the list update operations
* @return a future that will contain corresponding tuple once completed
* @throws TarantoolClientException in case if the request failed
*/
CompletableFuture update(Conditions conditions, TupleOperations operations);
/**
* Update a tuple. Only a single primary index value condition is supported.
*
* @param conditions query with options
* @param operations the list update operations
* @param options operation options
* @return a future that will contain corresponding tuple once completed
* @throws TarantoolClientException in case if the request failed
*/
default CompletableFuture update(Conditions conditions, TupleOperations operations, UpdateOptions options) {
return update(conditions, operations);
}
/**
* Update tuple if it would be found elsewhere try to insert tuple. Only a single primary index value condition
* is supported.
*
* @param conditions query with options
* @param tuple new data that will be insert if tuple will be not found
* @param operations the list of update operations to be performed if the tuple exists
* @return a future that will empty list
* @throws TarantoolClientException in case if the request failed
*/
CompletableFuture upsert(Conditions conditions, T tuple, TupleOperations operations);
/**
* Update tuple if it would be found elsewhere try to insert tuple. Only a single primary index value condition
* is supported.
*
* @param conditions query with options
* @param tuple new data that will be insert if tuple will be not found
* @param operations the list of update operations to be performed if the tuple exists
* @param options operation options
* @return a future that will empty list
* @throws TarantoolClientException in case if the request failed
*/
default CompletableFuture upsert(
Conditions conditions, T tuple, TupleOperations operations,
UpsertOptions options) {
return upsert(conditions, tuple, operations);
}
/**
* Truncate space if space would be found. Otherwise, throw space not found error.
*
* @return a future that will contain void.
* @throws TarantoolClientException in case if request failed
*/
CompletableFuture truncate() throws TarantoolClientException;
/**
* Get metadata associated with this space
*
* @return space metadata
*/
TarantoolSpaceMetadata getMetadata();
/**
* Cursor is an iterator-like object that is able to scroll through
* results of a query. Unlike a single cursor loads new tuples
* dynamically issuing requests to server.
*
* Select will fetch tuples matching the specified query.
* Each request to server will fetch no more than 'batch size' tuples.
*
* @param conditions query with options
* @param batchSize size of a batch of single client request
* @return cursor that can iterate through all corresponding tuples
*/
TarantoolCursor cursor(Conditions conditions, int batchSize);
/**
* Same as {@link TarantoolSpaceOperations#cursor(Conditions, int)}
* but uses the default batch size.
*
* @param conditions query with options
* @return cursor that can iterate through all corresponding tuples
*/
TarantoolCursor cursor(Conditions conditions);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy