Struct google_api_proto::google::spanner::v1::PartialResultSet
source · pub struct PartialResultSet {
pub metadata: Option<ResultSetMetadata>,
pub values: Vec<Value>,
pub chunked_value: bool,
pub resume_token: Bytes,
pub stats: Option<ResultSetStats>,
}
Expand description
Partial results from a streaming read or SQL query. Streaming reads and SQL queries better tolerate large result sets, large rows, and large values, but are a little trickier to consume.
Fields§
§metadata: Option<ResultSetMetadata>
Metadata about the result set, such as row type information. Only present in the first response.
values: Vec<Value>
A streamed result set consists of a stream of values, which might
be split into many PartialResultSet
messages to accommodate
large rows and/or large values. Every N complete values defines a
row, where N is equal to the number of entries in
[metadata.row_type.fields][google.spanner.v1.StructType.fields].
Most values are encoded based on type as described [here][google.spanner.v1.TypeCode].
It is possible that the last value in values is “chunked”,
meaning that the rest of the value is sent in subsequent
PartialResultSet
(s). This is denoted by the [chunked_value][google.spanner.v1.PartialResultSet.chunked_value]
field. Two or more chunked values can be merged to form a
complete value as follows:
bool/number/null
: cannot be chunkedstring
: concatenate the stringslist
: concatenate the lists. If the last element in a list is astring
,list
, orobject
, merge it with the first element in the next list by applying these rules recursively.object
: concatenate the (field name, field value) pairs. If a field name is duplicated, then apply these rules recursively to merge the field values.
Some examples of merging:
"foo", "bar" => "foobar"
\[2, 3\], \[4\] => \[2, 3, 4\]
\["a", "b"\], \["c", "d"\] => \["a", "bc", "d"\]
\["a", ["b", "c"]\], \[["d"\], "e"] => \["a", ["b", "cd"\], "e"]
{"a": "1"}, {"b": "2"} => {"a": "1", "b": 2"}
{"a": "1"}, {"a": "2"} => {"a": "12"}
{"a": \["1"\]}, {"a": \["2"\]} => {"a": \["12"\]}
For a more complete example, suppose a streaming SQL query is
yielding a result set whose rows contain a single string
field. The following PartialResultSet
s might be yielded:
{
"metadata": { ... }
"values": \["Hello", "W"\]
"chunked_value": true
"resume_token": "Af65..."
}
{
"values": \["orl"\]
"chunked_value": true
"resume_token": "Bqp2..."
}
{
"values": \["d"\]
"resume_token": "Zx1B..."
}
This sequence of PartialResultSet
s encodes two rows, one
containing the field value "Hello"
, and a second containing the
field value "World" = "W" + "orl" + "d"
.
chunked_value: bool
If true, then the final value in [values][google.spanner.v1.PartialResultSet.values] is chunked, and must
be combined with more values from subsequent PartialResultSet
s
to obtain a complete field value.
resume_token: Bytes
Streaming calls might be interrupted for a variety of reasons, such
as TCP connection loss. If this occurs, the stream of results can
be resumed by re-sending the original request and including
resume_token
. Note that executing any other transaction in the
same session invalidates the token.
stats: Option<ResultSetStats>
Query plan and execution statistics for the statement that produced this streaming result set. These can be requested by setting [ExecuteSqlRequest.query_mode][google.spanner.v1.ExecuteSqlRequest.query_mode] and are sent only once with the last response in the stream. This field will also be present in the last response for DML statements.
Trait Implementations§
source§impl Clone for PartialResultSet
impl Clone for PartialResultSet
source§fn clone(&self) -> PartialResultSet
fn clone(&self) -> PartialResultSet
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for PartialResultSet
impl Debug for PartialResultSet
source§impl Default for PartialResultSet
impl Default for PartialResultSet
source§impl Message for PartialResultSet
impl Message for PartialResultSet
source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
source§fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
source§fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
source§fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
source§fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
source§fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
source§fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
source§fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
. Read moresource§fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
.source§impl PartialEq for PartialResultSet
impl PartialEq for PartialResultSet
source§fn eq(&self, other: &PartialResultSet) -> bool
fn eq(&self, other: &PartialResultSet) -> bool
self
and other
values to be equal, and is used
by ==
.impl StructuralPartialEq for PartialResultSet
Auto Trait Implementations§
impl !Freeze for PartialResultSet
impl RefUnwindSafe for PartialResultSet
impl Send for PartialResultSet
impl Sync for PartialResultSet
impl Unpin for PartialResultSet
impl UnwindSafe for PartialResultSet
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request