tech.ydb.jooq.dsl.replace.ReplaceValuesStep9 Maven / Gradle / Ivy
package tech.ydb.jooq.dsl.replace;
import java.util.Collection;
import java.util.function.Function;
import org.jooq.CheckReturnValue;
import org.jooq.Field;
import org.jooq.Record;
import org.jooq.Record9;
import org.jooq.Row9;
import org.jooq.Rows;
import org.jooq.Select;
import org.jooq.Table;
import tech.ydb.jooq.Replace;
import tech.ydb.jooq.YdbDSLContext;
/**
* This type is used for the {@link Replace}'s DSL API.
*
* Example:
* using(configuration)
* .replaceInto(table, field1, field2, field3, .., field8, field9)
* .values(valueA1, valueA2, valueA3, .., valueA8, valueA9)
* .values(valueB1, valueB2, valueB3, .., valueB8, valueB9)
* .execute();
*
*/
public interface ReplaceValuesStep9 extends Replace {
/**
* Add a single row of values to the replace statement.
*/
@CheckReturnValue
ReplaceValuesStep9 values(T1 value1, T2 value2, T3 value3, T4 value4, T5 value5, T6 value6, T7 value7, T8 value8, T9 value9);
/**
* Add a single row of values to the replace statement.
*/
@CheckReturnValue
ReplaceValuesStep9 values(Field value1, Field value2, Field value3, Field value4, Field value5, Field value6, Field value7, Field value8, Field value9);
/**
* Add a single row of values to the replace statement.
*/
@CheckReturnValue
ReplaceValuesStep9 values(Collection> values);
/**
* Add a single row of values to the replace statement.
*/
@CheckReturnValue
ReplaceValuesStep9 values(Row9 values);
/**
* Add a single row of values to the replace statement.
*/
@CheckReturnValue
ReplaceValuesStep9 values(Record9 values);
/**
* Add multiple rows of values to the replace statement.
*
* This is equivalent to calling the other values clauses multiple times, but
* allows for dynamic construction of row arrays.
*
* @see Rows#toRowArray(Function, Function, Function, Function, Function, Function, Function, Function, Function)
*/
@CheckReturnValue
@SuppressWarnings("unchecked")
ReplaceValuesStep9 valuesOfRows(Row9... values);
/**
* Add multiple rows of values to the replace statement.
*
* This is equivalent to calling the other values clauses multiple times, but
* allows for dynamic construction of row arrays.
*
* @see Rows#toRowList(Function, Function, Function, Function, Function, Function, Function, Function, Function)
*/
@CheckReturnValue
ReplaceValuesStep9 valuesOfRows(Collection extends Row9> values);
/**
* Add multiple rows of values to the replace statement.
*
* This is equivalent to calling the other values clauses multiple times, but
* allows for dynamic construction of row arrays.
*
* Note: Irrespective of individual {@link Record#changed()}
* flag values, all record values are copied to the VALUES
clause
* using {@link Record#intoArray()}, to match replace columns by position, not
* by name. If you prefer omitting unchanged values and adding values by field
* name rather than by index, use {@link ReplaceSetStep#set(Record...)} instead.
* That syntax is available only if you omit the explicit replace columns list.
*/
@CheckReturnValue
@SuppressWarnings("unchecked")
ReplaceValuesStep9 valuesOfRecords(Record9... values);
/**
* Add multiple rows of values to the replace statement.
*
* This is equivalent to calling the other values clauses multiple times, but
* allows for dynamic construction of row arrays.
*
* Note: Irrespective of individual {@link Record#changed()}
* flag values, all record values are copied to the VALUES
clause
* using {@link Record#intoArray()}, to match replace columns by position, not
* by name. If you prefer omitting unchanged values and adding values by field
* name rather than by index, use {@link ReplaceSetStep#set(Record...)} instead.
* That syntax is available only if you omit the explicit replace columns list.
*/
@CheckReturnValue
ReplaceValuesStep9 valuesOfRecords(Collection extends Record9> values);
/**
* Use a SELECT
statement as the source of values for the
* REPLACE
statement
*
* This variant of the REPLACE … SELECT
statement expects a
* select returning exactly as many fields as specified previously in the
* INTO
clause:
* {@link YdbDSLContext#replaceInto(Table, Field, Field, Field, Field, Field, Field, Field, Field, Field)}
*/
@CheckReturnValue
Replace select(Select extends Record9> select);
}