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

com.couchbase.client.java.transactions.TransactionQueryOptions Maven / Gradle / Ivy

/*
 * Copyright 2022 Couchbase, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.couchbase.client.java.transactions;

import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.java.codec.JsonSerializer;
import com.couchbase.client.java.env.ClusterEnvironment;
import com.couchbase.client.java.json.JsonArray;
import com.couchbase.client.java.json.JsonObject;
import com.couchbase.client.java.query.QueryOptions;
import com.couchbase.client.java.query.QueryProfile;
import com.couchbase.client.java.query.QueryScanConsistency;

import java.time.Duration;

/**
 * Allows customizing various N1QL query options.
 * 

* This object is NOT thread safe and must be constructed on a single thread. */ public class TransactionQueryOptions { private QueryOptions builder = QueryOptions.queryOptions() // Metrics are currently always exposed as they add invaluable debugging .metrics(true); /** * The options should only be instantiated through the {@link #queryOptions()} static method. */ protected TransactionQueryOptions() {} /** * Creates new {@link QueryOptions} with all default params set. * * @return constructed {@link QueryOptions} with its default values. */ public static TransactionQueryOptions queryOptions() { return new TransactionQueryOptions(); } /** * Allows providing custom JSON key/value pairs for advanced usage. *

* If available, it is recommended to use the methods on this object to customize the query. This method should * only be used if no such setter can be found (i.e. if an undocumented property should be set or you are using * an older client and a new server-configuration property has been added to the cluster). *

* Note that the value will be passed through a JSON encoder, so do not provide already encoded JSON as the value. If * you want to pass objects or arrays, you can use {@link JsonObject} and {@link JsonArray} respectively. * * @param key the parameter name (key of the JSON property) or empty. * @param value the parameter value (value of the JSON property). * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions raw(final String key, final Object value) { builder.raw(key, value); return this; } /** * Allows turning this request into a prepared statement query. *

* If set to

false
, the SDK will transparently perform "prepare and execute" logic the first time this * query is seen and then subsequently reuse the prepared statement name when sending it to the server. If a query * is executed frequently, this is a good way to speed it up since it will save the server the task of re-parsing * and analyzing the query. *

* If you are using prepared statements, make sure that if certain parts of the query string change you are using * {@link #parameters(JsonObject) named} or {@link #parameters(JsonArray) positional} parameters. If the statement * string itself changes it cannot be cached. * * @param adhoc if set to false this query will be turned into a prepared statement query. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions adhoc(final boolean adhoc) { builder.adhoc(adhoc); return this; } /** * Customizes the consistency guarantees for this query. *

* Tuning the scan consistency allows to trade data "freshness" for latency and vice versa. By default * {@link QueryScanConsistency#REQUEST_PLUS} is used for any queries inside a transaction, which means that the * indexer will wait until any indexes used are consistent with all mutations at the time of the query. * If this level of consistency is not required, use {@link QueryScanConsistency#NOT_BOUNDED} which will execute * the query immediately with whatever data are in the index. *

* @param scanConsistency the index scan consistency to be used for this query. * @return this, for chaining purposes. */ public TransactionQueryOptions scanConsistency(final QueryScanConsistency scanConsistency) { builder.scanConsistency(scanConsistency); return this; } /** * Provides a custom {@link JsonSerializer} to be used for decoding the rows as they return from the server. *

* If no serializer is provided, the default one from the {@link ClusterEnvironment} will be used (which is * sufficient for most tasks at hand). * * @param serializer a custom serializer for this request. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions serializer(final JsonSerializer serializer) { builder.serializer(serializer); return this; } /** * Customizes the server profiling level for this query. *

* Note that you only want to tune this if you want to gather profiling/performance metrics for debugging. Turning * this on in production (depending on the level) will likely have performance impact on the server query engine * as a whole and on this query in particular! * * @param profile the custom query profile level for this query. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions profile(final QueryProfile profile) { builder.profile(profile); return this; } /** * Supports providing a custom client context ID for this query. *

* If no client context ID is provided by the user, a UUID is generated and sent automatically so by default it is * always possible to identify a query when debugging. If you do not want to send one, pass either null or an empty * string to this method. * * @param clientContextId the client context ID - if null or empty it will not be sent. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions clientContextId(final String clientContextId) { builder.clientContextId(clientContextId); return this; } /** * Allows customizing how long the query engine is willing to wait until the index catches up to whatever scan * consistency is asked for in this query. *

* Note that if {@link QueryScanConsistency#NOT_BOUNDED} is used, this method doesn't do anything * at all. If no value is provided to this method, the server default is used. * * @param wait the maximum duration the query engine is willing to wait before failing. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions scanWait(final Duration wait) { builder.scanWait(wait); return this; } /** * Allows explicitly marking a query as being readonly and not mutating and documents on the server side. *

* In addition to providing some security in that you are not accidentally modifying data, setting this flag to true * also helps the client to more proactively retry and re-dispatch a query since then it can be sure it is idempotent. * As a result, if your query is readonly then it is a good idea to set this flag. *

* If set to true, then (at least) the following statements are not allowed: *

    *
  1. CREATE INDEX
  2. *
  3. DROP INDEX
  4. *
  5. INSERT
  6. *
  7. MERGE
  8. *
  9. UPDATE
  10. *
  11. UPSERT
  12. *
  13. DELETE
  14. *
* * @param readonly true if readonly should be set, false is the default and will use the server side default. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions readonly(final boolean readonly) { builder.readonly(readonly); return this; } /** * Supports customizing the maximum buffered channel size between the indexer and the query service. *

* This is an advanced API and should only be tuned with care. Use 0 or a negative number to disable. * * @param scanCap the scan cap size, use 0 or negative number to disable. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions scanCap(final int scanCap) { builder.scanCap(scanCap); return this; } /** * Supports customizing the number of items execution operators can batch for fetch from the KV layer on the server. *

* This is an advanced API and should only be tuned with care. * * @param pipelineBatch the pipeline batch size. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions pipelineBatch(final int pipelineBatch) { builder.pipelineBatch(pipelineBatch); return this; } /** * Allows customizing the maximum number of items each execution operator can buffer between various operators on the * server. *

* This is an advanced API and should only be tuned with care. * * @param pipelineCap the pipeline cap size. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions pipelineCap(final int pipelineCap) { builder.pipelineCap(pipelineCap); return this; } /** * Sets named parameters for this query. *

* Note that named and positional parameters cannot be used at the same time. If one is set, the other one is "nulled" * out and not being sent to the server. * * @param named {@link JsonObject} the named parameters. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions parameters(final JsonObject named) { builder.parameters(named); return this; } /** * Sets positional parameters for this query. *

* Note that named and positional parameters cannot be used at the same time. If one is set, the other one is "nulled" * out and not being sent to the server. * * @param positional {@link JsonArray} the positional parameters. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions parameters(final JsonArray positional) { builder.parameters(positional); return this; } /** * Tells the query engine to use a flex index (utilizing the search service). * * @param flexIndex if a flex index should be used, false is the default. * @return the same {@link QueryOptions} for chaining purposes. */ public TransactionQueryOptions flexIndex(final boolean flexIndex) { builder.flexIndex(flexIndex); return this; } @Stability.Internal public QueryOptions builder() { return builder; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy