This is a range defined by the Input Iterators returned from its begin() and end() members. Callers may directly iterate the RowStream instance, which will return a sequence of StatusOr<Row> objects.
For convenience, callers may wrap instances in a StreamOf<std::tuple<...>> object, which will automatically parse each Row into a std::tuple with the specified types.
[[["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 provides documentation for the `RowStream` class in the Google Cloud Spanner C++ library, detailing its functionality and usage across various versions."],["`RowStream` represents a stream of `Rows` that is returned from `spanner::Client::Read()` or `spanner::Client::ExecuteQuery()`."],["The `RowStream` class supports iteration through its elements, with methods like `begin()` and `end()` that return a `RowStreamIterator` defining the range."],["Callers can wrap `RowStream` instances in a `StreamOf\u003cstd::tuple\u003c...\u003e\u003e` object for automatic parsing of each `Row` into a `std::tuple` with user specified types."],["The `RowsModified()` method returns the number of rows modified by a DML statement, and `ReadTimestamp()` provides the timestamp of the read if a read-only transaction is used."]]],[]]