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

com.google.api.services.spanner.v1.model.TransactionOptions Maven / Gradle / Ivy

There is a newer version: v1-rev20241119-2.0.0
Show newest version
/*
 * 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.
 */
/*
 * This code was generated by https://github.com/googleapis/google-api-java-client-services/
 * Modify at your own risk.
 */

package com.google.api.services.spanner.v1.model;

/**
 * Transactions: Each session can have at most one active transaction at a time (note that
 * standalone reads and queries use a transaction internally and do count towards the one
 * transaction limit). After the active transaction is completed, the session can immediately be re-
 * used for the next transaction. It is not necessary to create a new session for each transaction.
 * Transaction modes: Cloud Spanner supports three transaction modes: 1. Locking read-write. This
 * type of transaction is the only way to write data into Cloud Spanner. These transactions rely on
 * pessimistic locking and, if necessary, two-phase commit. Locking read-write transactions may
 * abort, requiring the application to retry. 2. Snapshot read-only. Snapshot read-only transactions
 * provide guaranteed consistency across several reads, but do not allow writes. Snapshot read-only
 * transactions can be configured to read at timestamps in the past, or configured to perform a
 * strong read (where Spanner will select a timestamp such that the read is guaranteed to see the
 * effects of all transactions that have committed before the start of the read). Snapshot read-only
 * transactions do not need to be committed. Queries on change streams must be performed with the
 * snapshot read-only transaction mode, specifying a strong read. See
 * TransactionOptions.ReadOnly.strong for more details. 3. Partitioned DML. This type of transaction
 * is used to execute a single Partitioned DML statement. Partitioned DML partitions the key space
 * and runs the DML statement over each partition in parallel using separate, internal transactions
 * that commit independently. Partitioned DML transactions do not need to be committed. For
 * transactions that only read, snapshot read-only transactions provide simpler semantics and are
 * almost always faster. In particular, read-only transactions do not take locks, so they do not
 * conflict with read-write transactions. As a consequence of not taking locks, they also do not
 * abort, so retry loops are not needed. Transactions may only read-write data in a single database.
 * They may, however, read-write data in different tables within that database. Locking read-write
 * transactions: Locking transactions may be used to atomically read-modify-write data anywhere in a
 * database. This type of transaction is externally consistent. Clients should attempt to minimize
 * the amount of time a transaction is active. Faster transactions commit with higher probability
 * and cause less contention. Cloud Spanner attempts to keep read locks active as long as the
 * transaction continues to do reads, and the transaction has not been terminated by Commit or
 * Rollback. Long periods of inactivity at the client may cause Cloud Spanner to release a
 * transaction's locks and abort it. Conceptually, a read-write transaction consists of zero or more
 * reads or SQL statements followed by Commit. At any time before Commit, the client can send a
 * Rollback request to abort the transaction. Semantics: Cloud Spanner can commit the transaction if
 * all read locks it acquired are still valid at commit time, and it is able to acquire write locks
 * for all writes. Cloud Spanner can abort the transaction for any reason. If a commit attempt
 * returns `ABORTED`, Cloud Spanner guarantees that the transaction has not modified any user data
 * in Cloud Spanner. Unless the transaction commits, Cloud Spanner makes no guarantees about how
 * long the transaction's locks were held for. It is an error to use Cloud Spanner locks for any
 * sort of mutual exclusion other than between Cloud Spanner transactions themselves. Retrying
 * aborted transactions: When a transaction aborts, the application can choose to retry the whole
 * transaction again. To maximize the chances of successfully committing the retry, the client
 * should execute the retry in the same session as the original attempt. The original session's lock
 * priority increases with each consecutive abort, meaning that each attempt has a slightly better
 * chance of success than the previous. Note that the lock priority is preserved per session (not
 * per transaction). Lock priority is set by the first read or write in the first attempt of a read-
 * write transaction. If the application starts a new session to retry the whole transaction, the
 * transaction loses its original lock priority. Moreover, the lock priority is only preserved if
 * the transaction fails with an `ABORTED` error. Under some circumstances (for example, many
 * transactions attempting to modify the same row(s)), a transaction can abort many times in a short
 * period before successfully committing. Thus, it is not a good idea to cap the number of retries a
 * transaction can attempt; instead, it is better to limit the total amount of time spent retrying.
 * Idle transactions: A transaction is considered idle if it has no outstanding reads or SQL queries
 * and has not started a read or SQL query within the last 10 seconds. Idle transactions can be
 * aborted by Cloud Spanner so that they don't hold on to locks indefinitely. If an idle transaction
 * is aborted, the commit will fail with error `ABORTED`. If this behavior is undesirable,
 * periodically executing a simple SQL query in the transaction (for example, `SELECT 1`) prevents
 * the transaction from becoming idle. Snapshot read-only transactions: Snapshot read-only
 * transactions provides a simpler method than locking read-write transactions for doing several
 * consistent reads. However, this type of transaction does not support writes. Snapshot
 * transactions do not take locks. Instead, they work by choosing a Cloud Spanner timestamp, then
 * executing all reads at that timestamp. Since they do not acquire locks, they do not block
 * concurrent read-write transactions. Unlike locking read-write transactions, snapshot read-only
 * transactions never abort. They can fail if the chosen read timestamp is garbage collected;
 * however, the default garbage collection policy is generous enough that most applications do not
 * need to worry about this in practice. Snapshot read-only transactions do not need to call Commit
 * or Rollback (and in fact are not permitted to do so). To execute a snapshot transaction, the
 * client specifies a timestamp bound, which tells Cloud Spanner how to choose a read timestamp. The
 * types of timestamp bound are: - Strong (the default). - Bounded staleness. - Exact staleness. If
 * the Cloud Spanner database to be read is geographically distributed, stale read-only transactions
 * can execute more quickly than strong or read-write transactions, because they are able to execute
 * far from the leader replica. Each type of timestamp bound is discussed in detail below. Strong:
 * Strong reads are guaranteed to see the effects of all transactions that have committed before the
 * start of the read. Furthermore, all rows yielded by a single read are consistent with each other
 * -- if any part of the read observes a transaction, all parts of the read see the transaction.
 * Strong reads are not repeatable: two consecutive strong read-only transactions might return
 * inconsistent results if there are concurrent writes. If consistency across reads is required, the
 * reads should be executed within a transaction or at an exact read timestamp. Queries on change
 * streams (see below for more details) must also specify the strong read timestamp bound. See
 * TransactionOptions.ReadOnly.strong. Exact staleness: These timestamp bounds execute reads at a
 * user-specified timestamp. Reads at a timestamp are guaranteed to see a consistent prefix of the
 * global transaction history: they observe modifications done by all transactions with a commit
 * timestamp less than or equal to the read timestamp, and observe none of the modifications done by
 * transactions with a larger commit timestamp. They will block until all conflicting transactions
 * that may be assigned commit timestamps <= the read timestamp have finished. The timestamp can
 * either be expressed as an absolute Cloud Spanner commit timestamp or a staleness relative to the
 * current time. These modes do not require a "negotiation phase" to pick a timestamp. As a result,
 * they execute slightly faster than the equivalent boundedly stale concurrency modes. On the other
 * hand, boundedly stale reads usually return fresher results. See
 * TransactionOptions.ReadOnly.read_timestamp and TransactionOptions.ReadOnly.exact_staleness.
 * Bounded staleness: Bounded staleness modes allow Cloud Spanner to pick the read timestamp,
 * subject to a user-provided staleness bound. Cloud Spanner chooses the newest timestamp within the
 * staleness bound that allows execution of the reads at the closest available replica without
 * blocking. All rows yielded are consistent with each other -- if any part of the read observes a
 * transaction, all parts of the read see the transaction. Boundedly stale reads are not repeatable:
 * two stale reads, even if they use the same staleness bound, can execute at different timestamps
 * and thus return inconsistent results. Boundedly stale reads execute in two phases: the first
 * phase negotiates a timestamp among all replicas needed to serve the read. In the second phase,
 * reads are executed at the negotiated timestamp. As a result of the two phase execution, bounded
 * staleness reads are usually a little slower than comparable exact staleness reads. However, they
 * are typically able to return fresher results, and are more likely to execute at the closest
 * replica. Because the timestamp negotiation requires up-front knowledge of which rows will be
 * read, it can only be used with single-use read-only transactions. See
 * TransactionOptions.ReadOnly.max_staleness and TransactionOptions.ReadOnly.min_read_timestamp. Old
 * read timestamps and garbage collection: Cloud Spanner continuously garbage collects deleted and
 * overwritten data in the background to reclaim storage space. This process is known as "version
 * GC". By default, version GC reclaims versions after they are one hour old. Because of this, Cloud
 * Spanner cannot perform reads at read timestamps more than one hour in the past. This restriction
 * also applies to in-progress reads and/or SQL queries whose timestamp become too old while
 * executing. Reads and SQL queries with too-old read timestamps fail with the error
 * `FAILED_PRECONDITION`. You can configure and extend the `VERSION_RETENTION_PERIOD` of a database
 * up to a period as long as one week, which allows Cloud Spanner to perform reads up to one week in
 * the past. Querying change Streams: A Change Stream is a schema object that can be configured to
 * watch data changes on the entire database, a set of tables, or a set of columns in a database.
 * When a change stream is created, Spanner automatically defines a corresponding SQL Table-Valued
 * Function (TVF) that can be used to query the change records in the associated change stream using
 * the ExecuteStreamingSql API. The name of the TVF for a change stream is generated from the name
 * of the change stream: READ_. All queries on change stream TVFs must be executed using the
 * ExecuteStreamingSql API with a single-use read-only transaction with a strong read-only
 * timestamp_bound. The change stream TVF allows users to specify the start_timestamp and
 * end_timestamp for the time range of interest. All change records within the retention period is
 * accessible using the strong read-only timestamp_bound. All other TransactionOptions are invalid
 * for change stream queries. In addition, if TransactionOptions.read_only.return_read_timestamp is
 * set to true, a special value of 2^63 - 2 will be returned in the Transaction message that
 * describes the transaction, instead of a valid read timestamp. This special value should be
 * discarded and not used for any subsequent queries. Please see
 * https://cloud.google.com/spanner/docs/change-streams for more details on how to query the change
 * stream TVFs. Partitioned DML transactions: Partitioned DML transactions are used to execute DML
 * statements with a different execution strategy that provides different, and often better,
 * scalability properties for large, table-wide operations than DML in a ReadWrite transaction.
 * Smaller scoped statements, such as an OLTP workload, should prefer using ReadWrite transactions.
 * Partitioned DML partitions the keyspace and runs the DML statement on each partition in separate,
 * internal transactions. These transactions commit automatically when complete, and run
 * independently from one another. To reduce lock contention, this execution strategy only acquires
 * read locks on rows that match the WHERE clause of the statement. Additionally, the smaller per-
 * partition transactions hold locks for less time. That said, Partitioned DML is not a drop-in
 * replacement for standard DML used in ReadWrite transactions. - The DML statement must be fully-
 * partitionable. Specifically, the statement must be expressible as the union of many statements
 * which each access only a single row of the table. - The statement is not applied atomically to
 * all rows of the table. Rather, the statement is applied atomically to partitions of the table, in
 * independent transactions. Secondary index rows are updated atomically with the base table rows. -
 * Partitioned DML does not guarantee exactly-once execution semantics against a partition. The
 * statement is applied at least once to each partition. It is strongly recommended that the DML
 * statement should be idempotent to avoid unexpected results. For instance, it is potentially
 * dangerous to run a statement such as `UPDATE table SET column = column + 1` as it could be run
 * multiple times against some rows. - The partitions are committed automatically - there is no
 * support for Commit or Rollback. If the call returns an error, or if the client issuing the
 * ExecuteSql call dies, it is possible that some rows had the statement executed on them
 * successfully. It is also possible that statement was never executed against other rows. -
 * Partitioned DML transactions may only contain the execution of a single DML statement via
 * ExecuteSql or ExecuteStreamingSql. - If any error is encountered during the execution of the
 * partitioned DML operation (for instance, a UNIQUE INDEX violation, division by zero, or a value
 * that cannot be stored due to schema constraints), then the operation is stopped at that point and
 * an error is returned. It is possible that at this point, some partitions have been committed (or
 * even committed multiple times), and other partitions have not been run at all. Given the above,
 * Partitioned DML is good fit for large, database-wide, operations that are idempotent, such as
 * deleting old rows from a very large table.
 *
 * 

This is the Java data model class that specifies how to parse/serialize into the JSON that is * transmitted over HTTP when working with the Cloud Spanner API. For a detailed explanation see: * https://developers.google.com/api-client-library/java/google-http-java-client/json *

* * @author Google, Inc. */ @SuppressWarnings("javadoc") public final class TransactionOptions extends com.google.api.client.json.GenericJson { /** * When `exclude_txn_from_change_streams` is set to `true`: * Modifications from this transaction * will not be recorded in change streams with DDL option `allow_txn_exclusion=true` that are * tracking columns modified by these transactions. * Modifications from this transaction will be * recorded in change streams with DDL option `allow_txn_exclusion=false or not set` that are * tracking columns modified by these transactions. When `exclude_txn_from_change_streams` is set * to `false` or not set, Modifications from this transaction will be recorded in all change * streams that are tracking columns modified by these transactions. * `exclude_txn_from_change_streams` may only be specified for read-write or partitioned-dml * transactions, otherwise the API will return an `INVALID_ARGUMENT` error. * The value may be {@code null}. */ @com.google.api.client.util.Key private java.lang.Boolean excludeTxnFromChangeStreams; /** * Partitioned DML transaction. Authorization to begin a Partitioned DML transaction requires * `spanner.databases.beginPartitionedDmlTransaction` permission on the `session` resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private PartitionedDml partitionedDml; /** * Transaction will not write. Authorization to begin a read-only transaction requires * `spanner.databases.beginReadOnlyTransaction` permission on the `session` resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private ReadOnly readOnly; /** * Transaction may write. Authorization to begin a read-write transaction requires * `spanner.databases.beginOrRollbackReadWriteTransaction` permission on the `session` resource. * The value may be {@code null}. */ @com.google.api.client.util.Key private ReadWrite readWrite; /** * When `exclude_txn_from_change_streams` is set to `true`: * Modifications from this transaction * will not be recorded in change streams with DDL option `allow_txn_exclusion=true` that are * tracking columns modified by these transactions. * Modifications from this transaction will be * recorded in change streams with DDL option `allow_txn_exclusion=false or not set` that are * tracking columns modified by these transactions. When `exclude_txn_from_change_streams` is set * to `false` or not set, Modifications from this transaction will be recorded in all change * streams that are tracking columns modified by these transactions. * `exclude_txn_from_change_streams` may only be specified for read-write or partitioned-dml * transactions, otherwise the API will return an `INVALID_ARGUMENT` error. * @return value or {@code null} for none */ public java.lang.Boolean getExcludeTxnFromChangeStreams() { return excludeTxnFromChangeStreams; } /** * When `exclude_txn_from_change_streams` is set to `true`: * Modifications from this transaction * will not be recorded in change streams with DDL option `allow_txn_exclusion=true` that are * tracking columns modified by these transactions. * Modifications from this transaction will be * recorded in change streams with DDL option `allow_txn_exclusion=false or not set` that are * tracking columns modified by these transactions. When `exclude_txn_from_change_streams` is set * to `false` or not set, Modifications from this transaction will be recorded in all change * streams that are tracking columns modified by these transactions. * `exclude_txn_from_change_streams` may only be specified for read-write or partitioned-dml * transactions, otherwise the API will return an `INVALID_ARGUMENT` error. * @param excludeTxnFromChangeStreams excludeTxnFromChangeStreams or {@code null} for none */ public TransactionOptions setExcludeTxnFromChangeStreams(java.lang.Boolean excludeTxnFromChangeStreams) { this.excludeTxnFromChangeStreams = excludeTxnFromChangeStreams; return this; } /** * Partitioned DML transaction. Authorization to begin a Partitioned DML transaction requires * `spanner.databases.beginPartitionedDmlTransaction` permission on the `session` resource. * @return value or {@code null} for none */ public PartitionedDml getPartitionedDml() { return partitionedDml; } /** * Partitioned DML transaction. Authorization to begin a Partitioned DML transaction requires * `spanner.databases.beginPartitionedDmlTransaction` permission on the `session` resource. * @param partitionedDml partitionedDml or {@code null} for none */ public TransactionOptions setPartitionedDml(PartitionedDml partitionedDml) { this.partitionedDml = partitionedDml; return this; } /** * Transaction will not write. Authorization to begin a read-only transaction requires * `spanner.databases.beginReadOnlyTransaction` permission on the `session` resource. * @return value or {@code null} for none */ public ReadOnly getReadOnly() { return readOnly; } /** * Transaction will not write. Authorization to begin a read-only transaction requires * `spanner.databases.beginReadOnlyTransaction` permission on the `session` resource. * @param readOnly readOnly or {@code null} for none */ public TransactionOptions setReadOnly(ReadOnly readOnly) { this.readOnly = readOnly; return this; } /** * Transaction may write. Authorization to begin a read-write transaction requires * `spanner.databases.beginOrRollbackReadWriteTransaction` permission on the `session` resource. * @return value or {@code null} for none */ public ReadWrite getReadWrite() { return readWrite; } /** * Transaction may write. Authorization to begin a read-write transaction requires * `spanner.databases.beginOrRollbackReadWriteTransaction` permission on the `session` resource. * @param readWrite readWrite or {@code null} for none */ public TransactionOptions setReadWrite(ReadWrite readWrite) { this.readWrite = readWrite; return this; } @Override public TransactionOptions set(String fieldName, Object value) { return (TransactionOptions) super.set(fieldName, value); } @Override public TransactionOptions clone() { return (TransactionOptions) super.clone(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy