All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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