pub enum QueryPlan {
TableScan {
table: String,
columns: Vec<String>,
predicate: Option<Box<QueryPlan>>,
},
IndexSeek {
index: String,
key_range: KeyRange,
},
Filter {
input: Box<QueryPlan>,
predicate: Predicate,
},
Project {
input: Box<QueryPlan>,
columns: Vec<String>,
},
Sort {
input: Box<QueryPlan>,
order_by: Vec<(String, bool)>,
},
Limit {
input: Box<QueryPlan>,
count: usize,
offset: usize,
},
Empty,
}Expand description
Query plan operators
Variants§
TableScan
Full table scan
IndexSeek
Index seek (primary or secondary)
Filter
Filter rows
Project
Project columns
Sort
Sort results
Limit
Limit results
Empty
Empty result
Trait Implementations§
Auto Trait Implementations§
impl Freeze for QueryPlan
impl RefUnwindSafe for QueryPlan
impl Send for QueryPlan
impl Sync for QueryPlan
impl Unpin for QueryPlan
impl UnsafeUnpin for QueryPlan
impl UnwindSafe for QueryPlan
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<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 more