- 6.102.0 (latest)
- 6.101.1
- 6.100.0
- 6.99.0
- 6.98.1
- 6.97.1
- 6.96.1
- 6.95.1
- 6.94.0
- 6.93.0
- 6.89.0
- 6.88.0
- 6.87.0
- 6.86.0
- 6.85.0
- 6.83.0
- 6.82.0
- 6.80.1
- 6.79.0
- 6.77.0
- 6.74.1
- 6.72.0
- 6.71.0
- 6.69.0
- 6.68.0
- 6.66.0
- 6.65.1
- 6.62.0
- 6.60.0
- 6.58.0
- 6.57.0
- 6.56.0
- 6.55.0
- 6.54.0
- 6.53.0
- 6.52.1
- 6.51.0
- 6.50.1
- 6.49.0
- 6.25.1
- 6.24.0
- 6.23.4
- 6.22.0
- 6.21.2
- 6.20.0
- 6.19.1
- 6.18.0
- 6.17.4
- 6.14.1
public interface AsyncTransactionManager extends AutoCloseableAn interface for managing the life cycle of a read write transaction including all its retries. See TransactionContext for a description of transaction semantics.
At any point in time there can be at most one active transaction in this manager. When that
 transaction is committed, if it fails with an ABORTED error, calling #resetForRetryAsync() would create a new TransactionContextFuture. The newly created
 transaction would use the same session thus increasing its lock priority. If the transaction is
 committed successfully, or is rolled back or commit fails with any error other than 
 ABORTED, the manager is considered complete and no further transactions are allowed to be
 created in it.
Every AsyncTransactionManager should either be committed or rolled back. Failure to do
 so can cause resources to be leaked and deadlocks. Easiest way to guarantee this is by calling
 #close() in a finally block.
Implements
AutoCloseableMethods
beginAsync()
public abstract AsyncTransactionManager.TransactionContextFuture beginAsync()Creates a new read write transaction. This must be called before doing any other operation and can only be called once. To create a new transaction for subsequent retries, see #resetForRetry().
| Type | Description | 
| AsyncTransactionManager.TransactionContextFuture | 
close()
public abstract void close()Closes the manager. If there is an active transaction, it will be rolled back. Underlying session will be released back to the session pool.
closeAsync()
public abstract ApiFuture<Void> closeAsync()Closes the transaction manager. If there is an active transaction, it will be rolled back. The underlying session will be released back to the session pool. The returned ApiFuture is done when the transaction (if any) has been rolled back.
| Type | Description | 
| ApiFuture<Void> | 
getCommitResponse()
public abstract ApiFuture<CommitResponse> getCommitResponse()Returns the CommitResponse of this transaction.
| Type | Description | 
| ApiFuture<CommitResponse> | 
getState()
public abstract TransactionManager.TransactionState getState()Returns the state of the transaction.
| Type | Description | 
| TransactionManager.TransactionState | 
resetForRetryAsync()
public abstract AsyncTransactionManager.TransactionContextFuture resetForRetryAsync()Creates a new transaction for retry. This should only be called if the previous transaction
 failed with ABORTED. In all other cases, this will throw an IllegalStateException. Users should backoff before calling this method. Backoff delay is
 specified by SpannerException#getRetryDelayInMillis() on the SpannerException
 throw by the previous commit call.
| Type | Description | 
| AsyncTransactionManager.TransactionContextFuture | 
rollbackAsync()
public abstract ApiFuture<Void> rollbackAsync()Rolls back the currently active transaction. In most cases there should be no need to call this explicitly since #close() would automatically roll back any active transaction.
| Type | Description | 
| ApiFuture<Void> |