The KeySet class is a regular type that represents a collection of Keys.
Users can construct a KeySet instance, then add Keys and ranges of Keys to the set. The caller is responsible for ensuring that all keys in a given KeySet instance contain the same number and types of values.
Users may also optionally construct an instance that represents all keys with KeySet::All().
Example
auto delete_albums = spanner::DeleteMutationBuilder( "Albums", spanner::KeySet() .AddKey(spanner::MakeKey(2,1)) .AddKey(spanner::MakeKey(2,3))) .Build();
// Delete all the performances, venues, albums and singers. auto commit = client.Commit(spanner::Mutations{ spanner::MakeDeleteMutation("Performances", spanner::KeySet::All()), spanner::MakeDeleteMutation("Venues", spanner::KeySet::All()), spanner::MakeDeleteMutation("Albums", spanner::KeySet::All()), spanner::MakeDeleteMutation("Singers", spanner::KeySet::All()), }); if(!commit)throw std::move(commit).status(); std::cout <<"delete-all was successful\n"; }
// Delete all the performances, venues, albums and singers. auto commit = client.Commit(spanner::Mutations{ spanner::MakeDeleteMutation("Performances", spanner::KeySet::All()), spanner::MakeDeleteMutation("Venues", spanner::KeySet::All()), spanner::MakeDeleteMutation("Albums", spanner::KeySet::All()), spanner::MakeDeleteMutation("Singers", spanner::KeySet::All()), }); if(!commit)throw std::move(commit).status(); std::cout <<"delete-all was successful\n"; }
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-03-21 UTC."],[[["This webpage details the `KeySet` class within the Google Cloud Spanner C++ library, used to represent collections of `Key` objects."],["The `KeySet` class allows users to construct a `KeySet` instance and populate it with individual `Key`s or ranges of `Key`s, ensuring that the `Key`s within a `KeySet` share the same number and types of values."],["A `KeySet` can represent all keys of a table or index using the `KeySet::All()` function, enabling operations like deleting all rows."],["The library provides functionalities for constructing, copying, and assigning `KeySet` instances, as well as methods for adding keys and key ranges via `AddKey` and `AddRange`."],["This page also contains links to past versions of the `KeySet` from 2.11.0 to 2.36.0, and has a link to the latest release candidate version 2.37.0-rc."]]],[]]