pub enum WindowFrameContext {
Rows(Arc<WindowFrame>),
Range {
window_frame: Arc<WindowFrame>,
state: WindowFrameStateRange,
},
Groups {
window_frame: Arc<WindowFrame>,
state: WindowFrameStateGroups,
},
}Expand description
This object stores the window frame state for use in incremental calculations.
Variants§
Rows(Arc<WindowFrame>)
ROWS frames are inherently stateless.
Range
RANGE frames are stateful, they store indices specifying where the previous search left off. This amortizes the overall cost to O(n) where n denotes the row count.
Groups
GROUPS frames are stateful, they store group boundaries and indices specifying where the previous search left off. This amortizes the overall cost to O(n) where n denotes the row count.
Implementations§
source§impl WindowFrameContext
impl WindowFrameContext
sourcepub fn new(
window_frame: Arc<WindowFrame>,
sort_options: Vec<SortOptions>,
) -> WindowFrameContext
pub fn new( window_frame: Arc<WindowFrame>, sort_options: Vec<SortOptions>, ) -> WindowFrameContext
Create a new state object for the given window frame.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for WindowFrameContext
impl !RefUnwindSafe for WindowFrameContext
impl Send for WindowFrameContext
impl Sync for WindowFrameContext
impl Unpin for WindowFrameContext
impl !UnwindSafe for WindowFrameContext
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> 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