Struct mz_compute_client::plan::reduce::KeyValPlan
source · pub struct KeyValPlan {
pub key_plan: SafeMfpPlan,
pub val_plan: SafeMfpPlan,
}Expand description
Plan for extracting keys and values in preparation for a reduction.
Fields§
§key_plan: SafeMfpPlanExtracts the columns used as the key.
val_plan: SafeMfpPlanExtracts the columns used to feed the aggregations.
Implementations§
source§impl KeyValPlan
impl KeyValPlan
sourcepub fn new(
input_arity: usize,
group_key: &[MirScalarExpr],
aggregates: &[AggregateExpr],
input_permutation_and_new_arity: Option<(BTreeMap<usize, usize>, usize)>
) -> Self
pub fn new( input_arity: usize, group_key: &[MirScalarExpr], aggregates: &[AggregateExpr], input_permutation_and_new_arity: Option<(BTreeMap<usize, usize>, usize)> ) -> Self
Create a new KeyValPlan from aggregation arguments.
Trait Implementations§
source§impl Arbitrary for KeyValPlan
impl Arbitrary for KeyValPlan
§type Parameters = (<SafeMfpPlan as Arbitrary>::Parameters, <SafeMfpPlan as Arbitrary>::Parameters)
type Parameters = (<SafeMfpPlan as Arbitrary>::Parameters, <SafeMfpPlan as Arbitrary>::Parameters)
The type of parameters that
arbitrary_with accepts for configuration
of the generated Strategy. Parameters must implement Default.§type Strategy = Map<(<SafeMfpPlan as Arbitrary>::Strategy, <SafeMfpPlan as Arbitrary>::Strategy), fn(_: (SafeMfpPlan, SafeMfpPlan)) -> KeyValPlan>
type Strategy = Map<(<SafeMfpPlan as Arbitrary>::Strategy, <SafeMfpPlan as Arbitrary>::Strategy), fn(_: (SafeMfpPlan, SafeMfpPlan)) -> KeyValPlan>
The type of
Strategy used to generate values of type Self.source§fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
source§impl Clone for KeyValPlan
impl Clone for KeyValPlan
source§fn clone(&self) -> KeyValPlan
fn clone(&self) -> KeyValPlan
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moresource§impl Debug for KeyValPlan
impl Debug for KeyValPlan
source§impl<'de> Deserialize<'de> for KeyValPlan
impl<'de> Deserialize<'de> for KeyValPlan
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl PartialEq<KeyValPlan> for KeyValPlan
impl PartialEq<KeyValPlan> for KeyValPlan
source§fn eq(&self, other: &KeyValPlan) -> bool
fn eq(&self, other: &KeyValPlan) -> bool
This method tests for
self and other values to be equal, and is used
by ==.source§impl RustType<ProtoKeyValPlan> for KeyValPlan
impl RustType<ProtoKeyValPlan> for KeyValPlan
source§fn into_proto(&self) -> ProtoKeyValPlan
fn into_proto(&self) -> ProtoKeyValPlan
Convert a
Self into a Proto value.source§fn from_proto(proto: ProtoKeyValPlan) -> Result<Self, TryFromProtoError>
fn from_proto(proto: ProtoKeyValPlan) -> Result<Self, TryFromProtoError>
source§impl Serialize for KeyValPlan
impl Serialize for KeyValPlan
impl Eq for KeyValPlan
impl StructuralEq for KeyValPlan
impl StructuralPartialEq for KeyValPlan
Auto Trait Implementations§
impl RefUnwindSafe for KeyValPlan
impl Send for KeyValPlan
impl Sync for KeyValPlan
impl Unpin for KeyValPlan
impl UnwindSafe for KeyValPlan
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
Mutably borrows from an owned value. Read more
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§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>
Wrap the input message
T in a tonic::Requestsource§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
impl<P, R> ProtoType<R> for Pwhere R: RustType<P>,
source§fn into_rust(self) -> Result<R, TryFromProtoError>
fn into_rust(self) -> Result<R, TryFromProtoError>
See
RustType::from_proto.source§fn from_rust(rust: &R) -> P
fn from_rust(rust: &R) -> P
See
RustType::into_proto.