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

io.tarantool.driver.api.tuple.TarantoolTuple Maven / Gradle / Ivy

package io.tarantool.driver.api.tuple;

import io.tarantool.driver.protocol.Packable;

import java.math.BigDecimal;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.UUID;

/**
 * Basic Tarantool atom of data
 *
 * @author Alexey Kuzin
 */
public interface TarantoolTuple extends Iterable, Packable {
    /**
     * Get a tuple field by its position
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return field or empty optional if the field position is out of tuple length
     */
    Optional getField(int fieldPosition);

    /**
     * Get a tuple field by its name
     *
     * @param fieldName the field name in space
     * @return field or empty optional if the field not exist in space
     */
    Optional getField(String fieldName);

    /**
     * Get all tuple fields as list
     *
     * @return all tuple fields as list
     */
    List getFields();

    /**
     * Get a tuple field value by its position specifying the target value type
     *
     * @param fieldPosition field position from the the tuple start, starting from 0
     * @param objectClass   target value type class
     * @param            target value type
     * @return nullable value of a field wrapped in Optional, possibly converted to a Java type
     */
     Optional getObject(int fieldPosition, Class objectClass);

    /**
     * Check if a tuple field exists and can be converted to the target value type
     *
     * @param fieldPosition field position from the the tuple start, starting from 0
     * @param objectClass   target value type class
     * @return true, if the field exists and can be converted to the given type, false otherwise
     */
    boolean canGetObject(int fieldPosition, Class objectClass);

    /**
     * Get a tuple field value by its name specifying the target value type
     *
     * @param fieldName   field name, should not be null
     * @param objectClass target value type class
     * @param          target value type
     * @return nullable value of a field wrapped in Optional, possibly converted to a Java type
     */
     Optional getObject(String fieldName, Class objectClass);

    /**
     * Check if a tuple field exists and can be converted to the target value type
     *
     * @param fieldName   field name, should not be null
     * @param objectClass target value type class
     * @return true, if the field exists and can be converted to the given type, false otherwise
     */
    boolean canGetObject(String fieldName, Class objectClass);

    /**
     * Get a tuple field value as a raw object
     *
     * @param fieldPosition field position from the the tuple start, starting from 0
     * @return nullable value of a field wrapped in Optional
     */
    Optional getObject(int fieldPosition);

    /**
     * Get a tuple field value as a raw object
     *
     * @param fieldName field name, should not be null
     * @return nullable value of a field wrapped in Optional
     */
    Optional getObject(String fieldName);

    /**
     * Get the number of fields in this tuple
     *
     * @return the number of fields in this tuple
     */
    int size();

    /**
     * Set a tuple field by field position
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @param field         new field
     */
    void setField(int fieldPosition, TarantoolField field);

    /**
     * Set a tuple field by field name
     *
     * @param fieldName the field name, must be not null
     * @param field     new field
     */
    void setField(String fieldName, TarantoolField field);

    /**
     * Set a tuple field value from an object by field position
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @param value         new field value
     */
    void putObject(int fieldPosition, Object value);

    /**
     * Set a tuple field value from an object by field name
     *
     * @param fieldName the field name, must not be null
     * @param value     new field value
     */
    void putObject(String fieldName, Object value);

    /**
     * Get the field value converted to {@code byte[]}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    byte[] getByteArray(int fieldPosition);

    /**
     * Get the field value converted to {@code byte[]}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    byte[] getByteArray(String fieldName);

    /**
     * Get the field value converted to {@code Boolean}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Boolean getBoolean(int fieldPosition);

    /**
     * Get the field value converted to {@code Boolean}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Boolean getBoolean(String fieldName);

    /**
     * Get the field value converted to {@code Double}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Double getDouble(int fieldPosition);

    /**
     * Get the field value converted to {@code Double}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Double getDouble(String fieldName);

    /**
     * Get the field value converted to {@code Float}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Float getFloat(int fieldPosition);

    /**
     * Get the field value converted to {@code Float}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Float getFloat(String fieldName);

    /**
     * Get the field value converted to {@code Integer}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Integer getInteger(int fieldPosition);

    /**
     * Get the field value converted to {@code Integer}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Integer getInteger(String fieldName);

    /**
     * Get the field value converted to {@code Long}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Long getLong(int fieldPosition);

    /**
     * Get the field value converted to {@code Long}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Long getLong(String fieldName);

    /**
     * Get the field value converted to {@code String}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    String getString(int fieldPosition);

    /**
     * Get the field value converted to {@code String}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    String getString(String fieldName);

    /**
     * Get the field value converted to {@code Character}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Character getCharacter(int fieldPosition);

    /**
     * Get the field value converted to {@code Character}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Character getCharacter(String fieldName);

    /**
     * Get the field value converted to {@link UUID}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    UUID getUUID(int fieldPosition);

    /**
     * Get the field value converted to {@link UUID}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    UUID getUUID(String fieldName);

    /**
     * Get the field value converted to {@link BigDecimal}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    BigDecimal getDecimal(int fieldPosition);

    /**
     * Get the field value converted to {@link BigDecimal}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    BigDecimal getDecimal(String fieldName);

    /**
     * Get the field value converted to {@link List}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    List getList(int fieldPosition);

    /**
     * Get the field value converted to {@link List}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    List getList(String fieldName);

    /**
     * Get the field value converted to {@link Map}
     *
     * @param fieldPosition the field position from the the tuple start, starting from 0
     * @return value
     */
    Map getMap(int fieldPosition);

    /**
     * Get the field value converted to {@link Map}
     *
     * @param fieldName the field name, must not be null
     * @return value
     */
    Map getMap(String fieldName);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy