pub enum Determinism {
Pure,
SessionScoped,
Nondeterministic,
}Expand description
Determinism characterization — drives planner caching and hoisting.
Variants§
Pure
Same inputs always produce identical output. Cacheable; hoistable
from loops. Maps to DataFusion Volatility::Immutable.
SessionScoped
Stable within one session (e.g. current_user()). Maps to
DataFusion Volatility::Stable.
Nondeterministic
Non-deterministic (rand(), now()). Maps to DataFusion
Volatility::Volatile.
Trait Implementations§
Source§impl Clone for Determinism
impl Clone for Determinism
Source§fn clone(&self) -> Determinism
fn clone(&self) -> Determinism
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 moreimpl Copy for Determinism
Source§impl Debug for Determinism
impl Debug for Determinism
Source§impl Default for Determinism
impl Default for Determinism
Source§fn default() -> Determinism
fn default() -> Determinism
Returns the “default value” for a type. Read more
Source§impl<'de> Deserialize<'de> for Determinism
impl<'de> Deserialize<'de> for Determinism
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
impl Eq for Determinism
Source§impl PartialEq for Determinism
impl PartialEq for Determinism
Source§fn eq(&self, other: &Determinism) -> bool
fn eq(&self, other: &Determinism) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for Determinism
impl Serialize for Determinism
impl StructuralPartialEq for Determinism
Auto Trait Implementations§
impl Freeze for Determinism
impl RefUnwindSafe for Determinism
impl Send for Determinism
impl Sync for Determinism
impl Unpin for Determinism
impl UnsafeUnpin for Determinism
impl UnwindSafe for Determinism
Blanket Implementations§
impl<T> Allocation for T
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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