The base class for the Spanner library transaction rerun policies.
The Client::Commit() functions (there are several overloads) consume a callable to create mutations or a list of mutations. Commit() creates a transaction and applies the mutations. If the transaction fails, an instance of this class is used to control whether the transaction will be attempted again.
Functions
clone() const
Creates a new instance of the policy, reset to the initial state.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-22 UTC."],[[["\u003cp\u003eThis webpage details the \u003ccode\u003eTransactionRerunPolicy\u003c/code\u003e class within the Google Cloud Spanner C++ library, specifically for version 2.21.0, with links to other versions of the documentation.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003eTransactionRerunPolicy\u003c/code\u003e class is used to control whether a failed transaction should be retried by the \u003ccode\u003eClient::Commit()\u003c/code\u003e function, which applies mutations in a Spanner database transaction.\u003c/p\u003e\n"],["\u003cp\u003eThe class provides methods like \u003ccode\u003eclone()\u003c/code\u003e, \u003ccode\u003eOnFailure()\u003c/code\u003e, \u003ccode\u003eIsExhausted()\u003c/code\u003e, and \u003ccode\u003eIsPermanentFailure()\u003c/code\u003e to manage and assess transaction retries based on the status of the transaction.\u003c/p\u003e\n"],["\u003cp\u003eThe latest version is 2.37.0-rc, with many older version all the way back to 2.11.0.\u003c/p\u003e\n"]]],[],null,[]]