org.firebirdsql.gds.ng.FbBatchConfig Maven / Gradle / Ivy
Show all versions of jaybird Show documentation
/*
* Public Firebird Java API.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package org.firebirdsql.gds.ng;
import org.firebirdsql.gds.BatchParameterBuffer;
import java.util.stream.IntStream;
import static org.firebirdsql.jaybird.fb.constants.BatchItems.BLOB_ID_USER;
import static org.firebirdsql.jaybird.fb.constants.BatchItems.TAG_BLOB_POLICY;
import static org.firebirdsql.jaybird.fb.constants.BatchItems.TAG_BUFFER_BYTES_SIZE;
import static org.firebirdsql.jaybird.fb.constants.BatchItems.TAG_DETAILED_ERRORS;
import static org.firebirdsql.jaybird.fb.constants.BatchItems.TAG_MULTIERROR;
import static org.firebirdsql.jaybird.fb.constants.BatchItems.TAG_RECORD_COUNTS;
/**
* Configuration for a Firebird 4+ batch.
*
* @author Mark Rotteveel
* @since 5
*/
public interface FbBatchConfig {
// Constants exist to write more readable code when using FbBatchConfig.of(..) without resorting to a builder
/**
* {@link #multiError()} value to signal to continue execution on errors.
*/
boolean CONTINUE_ON_ERROR = true;
/**
* {@link #multiError()} value to signal to halt execution at first error.
*/
boolean HALT_AT_FIRST_ERROR = false;
/**
* {@link #updateCounts()} value to signal to supply update counts.
*/
boolean UPDATE_COUNTS = true;
/**
* {@link #updateCounts()} value to signal to no supply update counts.
*/
@SuppressWarnings("unused")
boolean NO_UPDATE_COUNTS = false;
/**
* {@link #detailedErrors()} value to signal to use server default detailed errors.
*
* NOTE: all negative values signal this. If you want to use this to check against a value,
* use {@code <= SERVER_DEFAULT_DETAILED_ERRORS}.
*
*/
int SERVER_DEFAULT_DETAILED_ERRORS = -1;
/**
* {@link #batchBufferSize()} value to signal to use server maximum batch buffer size.
*/
@SuppressWarnings("unused")
int SERVER_MAXIMUM_BUFFER_SIZE = 0;
/**
* {@link #batchBufferSize()} value to signal to use server default batch buffer size.
*
* NOTE: all negative values signal this. If you want to use this constant to check against a value,
* use {@code <= SERVER_DEFAULT_BUFFER_SIZE}.
*
*/
int SERVER_DEFAULT_BUFFER_SIZE = -1;
/**
* Multi-error behaviour.
*
* @return {@code true} request multi-error (continue on failure), or {@code false} to halt execution on first error
*/
boolean multiError();
/**
* Report update counts per element (called "record counts" in Firebird).
*
* @return {@code true} report update counts, {@code false} do not report update counts
*/
boolean updateCounts();
/**
* Number of detailed errors to return.
*
* A value of {@code 0} disables detailed errors. When a value {@code < 0} is returned, the server-side default is
* used ({@code 64 as of Firebird 4}). Requesting detailed errors exceeding the maximum (256 as of Firebird 4) will
* be silently set to the server maximum.
*
*
* @return number of detailed errors, {@code 0} to disable detailed errors, {@code < 0} for server default
*/
int detailedErrors();
/**
* Server-side batch buffer size in bytes.
*
* When a value {@code < 0} is returned, the server-side default (16MB as of Firebird 4) will be used.
* When a value of {@code 0} is returned , the server-side maximum will be used. Requesting buffer sizes exceeding
* the maximum (256MB as of Firebird 4) will be silently set to the server maximum.
*
*
* @return maximum batch buffer size, return {@code < 0} to use server-side default (16MB as of Firebird 4),
* {@code 0} for the server-side maximum (256MB as of Firebird 4)
*/
int batchBufferSize();
// No config option for blob-policy, as we haven't implemented batch blob handling yet
/**
* @return immutable, frozen copy of this batch config
*/
default FbBatchConfig immutable() {
return new Immutable(this);
}
/**
* Creates an immutable batch config.
*
* @return an immutable batch config with the specified configuration
*/
static FbBatchConfig of(boolean multiError, boolean updateCounts, int detailedErrors, int batchBufferSize) {
return new Immutable(multiError, updateCounts, detailedErrors, batchBufferSize);
}
/**
* Populates the provided batch parameter buffer with the configuration.
*
* This method will remove previously set items which are managed by this method. Items not managed by this method
* are untouched. At minimum this method manages items {@code TAG_MULTIERROR}, {@code TAG_RECORD_COUNTS},
* {@code TAG_DETAILED_ERRORS}, and {@code TAG_BUFFER_BYTES_SIZE}.
*
*
* @param batchPb
* batch parameter buffer to populate.
*/
default void populateBatchParameterBuffer(BatchParameterBuffer batchPb) {
IntStream.of(TAG_MULTIERROR, TAG_RECORD_COUNTS, TAG_DETAILED_ERRORS, TAG_BUFFER_BYTES_SIZE, TAG_BLOB_POLICY)
.forEach(batchPb::removeArgument);
if (multiError()) {
batchPb.addArgument(TAG_MULTIERROR, 1);
}
if (updateCounts()) {
batchPb.addArgument(TAG_RECORD_COUNTS, 1);
}
if (detailedErrors() >= 0) {
batchPb.addArgument(TAG_DETAILED_ERRORS, detailedErrors());
}
if (batchBufferSize() >= 0) {
batchPb.addArgument(TAG_BUFFER_BYTES_SIZE, batchBufferSize());
}
// Doesn't seem to make a difference in current implementation, in practice we register existing blobs under
// their own id (see registerBlobs in V16Statement)
// TODO Might need to change when implementing batching of blobs
batchPb.addArgument(TAG_BLOB_POLICY, BLOB_ID_USER);
}
/**
* Class to provide an immutable copy of a batch config.
*/
final class Immutable implements FbBatchConfig {
private final boolean multiError;
private final boolean updateCounts;
private final int detailedErrors;
private final int batchBufferSize;
private Immutable(FbBatchConfig config) {
this(config.multiError(), config.updateCounts(), config.detailedErrors(), config.batchBufferSize());
}
private Immutable(boolean multiError, boolean updateCounts, int detailedErrors, int batchBufferSize) {
this.multiError = multiError;
this.updateCounts = updateCounts;
this.detailedErrors = detailedErrors;
this.batchBufferSize = batchBufferSize;
}
@Override
public boolean multiError() {
return multiError;
}
@Override
public boolean updateCounts() {
return updateCounts;
}
@Override
public int detailedErrors() {
return detailedErrors;
}
@Override
public int batchBufferSize() {
return batchBufferSize;
}
@Override
public FbBatchConfig immutable() {
return this;
}
}
}