AsyncTransaction(client, max_attempts=5, read_only=False)Accumulate read-and-write operations to be sent in a transaction.
| Parameters | |
|---|---|
| Name | Description | 
| client | AsyncClientThe client that created this transaction. | 
| max_attempts | Optional[int]The maximum number of attempts for the transaction (i.e. allowing retries). Defaults to MAX_ATTEMPTS. | 
| read_only | Optional[bool]Flag indicating if the transaction should be read-only or should allow writes. Defaults to :data: | 
Properties
id
Get the current transaction ID.
| Returns | |
|---|---|
| Type | Description | 
| Optional[bytes] | The transaction ID (or :data: Noneif the current transaction is not in progress). | 
in_progress
Determine if this transaction has already begun.
| Returns | |
|---|---|
| Type | Description | 
| bool | Indicates if the transaction has started. | 
Methods
commit
commit(
    retry: (
        google.api_core.retry.retry_unary_async.AsyncRetry | object | None
    ) = _MethodDefault._DEFAULT_VALUE,
    timeout: typing.Optional[float] = None,
) -> listCommit the changes accumulated in this batch.
| Parameters | |
|---|---|
| Name | Description | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. Defaults to a system-specified policy. | 
| timeout | floatThe timeout for this request. Defaults to a system-specified value. | 
| Returns | |
|---|---|
| Type | Description | 
| List[WriteResult, ...] | The write results corresponding to the changes committed, returned in the same order as the changes were applied to this batch. A write result contains an update_timefield. | 
create
create(
    reference: google.cloud.firestore_v1.base_document.BaseDocumentReference,
    document_data: dict,
) -> NoneAdd a "change" to this batch to create a document.
If the document given by reference already exists, then this
batch will fail when commit-ed.
| Parameters | |
|---|---|
| Name | Description | 
| reference | DocumentReferenceA document reference to be created in this batch. | 
| document_data | dictProperty names and values to use for creating a document. | 
delete
delete(
    reference: google.cloud.firestore_v1.base_document.BaseDocumentReference,
    option: typing.Optional[google.cloud.firestore_v1._helpers.WriteOption] = None,
) -> NoneAdd a "change" to delete a document.
See
xref_delete
for more information on how option determines how the change is
applied.
| Parameters | |
|---|---|
| Name | Description | 
| reference | DocumentReferenceA document reference that will be deleted in this batch. | 
| option | Optional[WriteOption]A write option to make assertions / preconditions on the server state of the document before applying changes. | 
get
get(
    ref_or_query: AsyncDocumentReference | AsyncQuery,
    retry: retries.AsyncRetry | object | None = _MethodDefault._DEFAULT_VALUE,
    timeout: Optional[float] = None,
    *,
    explain_options: Optional[ExplainOptions] = None
) -> AsyncGenerator[DocumentSnapshot, Any] | AsyncStreamGenerator[DocumentSnapshot]Retrieve a document or a query result from the database.
| Parameters | |
|---|---|
| Name | Description | 
| ref_or_query | AsyncDocumentReference AsyncQueryThe document references or query object to return. | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. Defaults to a system-specified policy. | 
| timeout | floatThe timeout for this request. Defaults to a system-specified value. | 
| Exceptions | |
|---|---|
| Type | Description | 
| ValueError | if ref_or_queryis not one of the supported types, or | 
| explain_option | is provided when ref_or_queryis a document: | 
| reference. | |
get_all
get_all(
    references: list,
    retry: retries.AsyncRetry | object | None = _MethodDefault._DEFAULT_VALUE,
    timeout: float | None = None,
) -> AsyncGenerator[DocumentSnapshot, Any]Retrieves multiple documents from Firestore.
| Parameters | |
|---|---|
| Name | Description | 
| references | List[.AsyncDocumentReference, ...]Iterable of document references to be retrieved. | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. Defaults to a system-specified policy. | 
| timeout | float :Yields: *.DocumentSnapshot* -- The next document snapshot that fulfills the query, or :data:The timeout for this request. Defaults to a system-specified value. | 
set
set(
    reference: google.cloud.firestore_v1.base_document.BaseDocumentReference,
    document_data: dict,
    merge: typing.Union[bool, list] = False,
) -> NoneAdd a "change" to replace a document.
See
xref_set for
more information on how option determines how the change is
applied.
| Parameters | |
|---|---|
| Name | Description | 
| reference | DocumentReferenceA document reference that will have values set in this batch. | 
| document_data | dictProperty names and values to use for replacing a document. | 
| merge | Optional[bool] or Optional[ListIf True, apply merging instead of overwriting the state of the document. | 
update
update(
    reference: google.cloud.firestore_v1.base_document.BaseDocumentReference,
    field_updates: dict,
    option: typing.Optional[google.cloud.firestore_v1._helpers.WriteOption] = None,
) -> NoneAdd a "change" to update a document.
See
xref_update
for more information on field_updates and option.
| Parameters | |
|---|---|
| Name | Description | 
| reference | DocumentReferenceA document reference that will be updated in this batch. | 
| field_updates | dictField names or paths to update and values to update with. | 
| option | Optional[WriteOption]A write option to make assertions / preconditions on the server state of the document before applying changes. |