pub enum QueryStep {
NodeScan {
shard_id: ShardId,
label: Option<String>,
filter: Option<String>,
},
EdgeScan {
shard_id: ShardId,
edge_type: Option<String>,
},
Join {
left_shard: ShardId,
right_shard: ShardId,
join_key: String,
},
Aggregate {
operation: AggregateOp,
group_by: Option<String>,
},
Filter {
predicate: String,
},
Sort {
key: String,
ascending: bool,
},
Limit {
count: usize,
},
}Expand description
Individual step in query execution
Variants§
NodeScan
Scan nodes with optional filter
EdgeScan
Scan edges
Join
Join results from multiple shards
Aggregate
Aggregate results
Filter
Filter results
Sort
Sort results
Limit
Limit results
Trait Implementations§
Source§impl<'de> Deserialize<'de> for QueryStep
impl<'de> Deserialize<'de> for QueryStep
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
Auto Trait Implementations§
impl Freeze for QueryStep
impl RefUnwindSafe for QueryStep
impl Send for QueryStep
impl Sync for QueryStep
impl Unpin for QueryStep
impl UnwindSafe for QueryStep
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 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