pub enum DecorrelationStrategy {
JoinWithGroupBy {
group_by_cols: Vec<String>,
join_condition: Vec<(String, String)>,
},
LeftJoinWithGroupBy {
group_by_cols: Vec<String>,
join_condition: Vec<(String, String)>,
},
SemiJoin {
join_condition: Vec<(String, String)>,
},
AntiJoin {
join_condition: Vec<(String, String)>,
},
DistinctJoin {
join_condition: Vec<(String, String)>,
},
}Expand description
Strategy for decorrelating a subquery
Variants§
JoinWithGroupBy
Convert to INNER JOIN with GROUP BY on correlation columns Used for scalar subqueries with aggregation
Fields
LeftJoinWithGroupBy
Convert to LEFT JOIN (for nullable results)
SemiJoin
Convert IN subquery to SEMI JOIN
AntiJoin
Convert NOT IN/NOT EXISTS to ANTI JOIN
DistinctJoin
Apply DISTINCT to inner query and join Used when inner returns duplicates but only existence matters
Trait Implementations§
Source§impl Clone for DecorrelationStrategy
impl Clone for DecorrelationStrategy
Source§fn clone(&self) -> DecorrelationStrategy
fn clone(&self) -> DecorrelationStrategy
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · 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 DecorrelationStrategy
impl Debug for DecorrelationStrategy
Source§impl PartialEq for DecorrelationStrategy
impl PartialEq for DecorrelationStrategy
Source§fn eq(&self, other: &DecorrelationStrategy) -> bool
fn eq(&self, other: &DecorrelationStrategy) -> bool
Tests for
self and other values to be equal, and is used by ==.impl Eq for DecorrelationStrategy
impl StructuralPartialEq for DecorrelationStrategy
Auto Trait Implementations§
impl Freeze for DecorrelationStrategy
impl RefUnwindSafe for DecorrelationStrategy
impl Send for DecorrelationStrategy
impl Sync for DecorrelationStrategy
impl Unpin for DecorrelationStrategy
impl UnsafeUnpin for DecorrelationStrategy
impl UnwindSafe for DecorrelationStrategy
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<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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> 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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§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::Request