- 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 static interface AsyncRunner.AsyncWork<R>Functional interface for executing a read/write transaction asynchronously that returns a result of type R.
| Type Parameter | |
|---|---|
| Name | Description | 
| R | |
Methods
doWorkAsync(TransactionContext txn)
public abstract ApiFuture<R> doWorkAsync(TransactionContext txn)Performs a single transaction attempt. All reads/writes should be performed using 
 txn.
Implementations of this method should not attempt to commit the transaction directly: returning normally will result in the runner attempting to commit the transaction once the returned future completes, retrying on abort.
In most cases, the implementation will not need to catch SpannerExceptions from
 Spanner operations, instead letting these propagate to the framework. The transaction runner
 will take appropriate action based on the type of exception. In particular, implementations
 should never catch an exception of type Code#ABORTED: these indicate that some reads
 may have returned inconsistent data and the transaction attempt must be aborted.
| Parameter | |
|---|---|
| Name | Description | 
| txn | TransactionContextthe transaction | 
| Returns | |
|---|---|
| Type | Description | 
| ApiFuture<R> | future over the result of the work |