Skip to main content

Optional

Struct Optional 

Source
pub struct Optional<'outer, 'inner, S> { /* private fields */ }
Expand description

This is the argument type used by the optional combinator.

Joining more optional columns can be done with the Optional::and method. Finally it is possible to return expressions or selections using Optional::then and Optional::then_select.

Implementations§

Source§

impl<'outer, 'inner, S> Optional<'outer, 'inner, S>

Source

pub fn and<T: EqTyp>( &mut self, col: impl IntoExpr<'inner, S, Typ = Option<T>>, ) -> Expr<'inner, S, T>

Join an optional column to the current row.

If the joined column is None, then the whole row will become None, from that moment forward.

let (total1, total2) = txn.query_one(optional(|row| {
    let val1 = row.and(Some(100));
    let val2 = row.and(Some(20));
    let total = val1.add(val2);
    let total1 = row.then(&total);

    let _ = row.and(None::<i64>);
    let total2 = row.then(total);

     (total1, total2)
}));
assert_eq!(total1, Some(120));
assert_eq!(total2, None);
Source

pub fn is_none(&self) -> Expr<'outer, S, bool>

Return a bool column indicating whether the current row does not exists.

let (none1, none2) = txn.query_one(optional(|row| {
    let none1 = row.is_none();
    let _ = row.and(None::<i64>);
    let none2 = row.is_none();
    (none1, none2)
}));
assert_eq!(none1, false);
assert_eq!(none2, true);
Source

pub fn is_some(&self) -> Expr<'outer, S, bool>

Return a bool column indicating whether the current row exists.

let (some1, some2) = txn.query_one(optional(|row| {
    let some1 = row.is_some();
    let _ = row.and(None::<i64>);
    let some2 = row.is_some();
    (some1, some2)
}));
assert_eq!(some1, true);
assert_eq!(some2, false);
Source

pub fn and_then<T: EqTyp>( &self, col: impl IntoExpr<'inner, S, Typ = Option<T>>, ) -> Expr<'outer, S, Option<T>>

This is much like combining Self::and with Self::then, but it allows returning an optional value without mutating the Optional row.

let (val1, val2) = txn.query_one(optional(|row| {
   let val1 = row.and_then(None::<i64>);
   let val2 = row.and_then(Some(1));
   (val1, val2)
}));
assert_eq!(val1, None);
assert_eq!(val2, Some(1));
Source

pub fn then<T: EqTyp + 'outer>( &self, col: impl IntoExpr<'inner, S, Typ = T>, ) -> Expr<'outer, S, Option<T>>

Return Some column if the current row exists and None column otherwise.

let (val1, val2) = txn.query_one(optional(|row| {
   let val1 = row.then(1);
   let _ = row.and(None::<i64>);
   let val2 = row.then(1);
   (val1, val2)
}));
assert_eq!(val1, Some(1));
assert_eq!(val2, None);
Source

pub fn then_select<Out: 'static>( &self, d: impl IntoSelect<'inner, S, Out = Out>, ) -> Select<'outer, S, Option<Out>>

Returns a Select with optional result. Useful for returning multiple values in a single Option.

let pair = txn.query_one(optional(|row| {
   let val1 = row.and(Some(1));
   let val2 = row.and(Some(2));
   row.then_select((val1, val2))
}));
assert_eq!(pair, Some((1, 2)));

Auto Trait Implementations§

§

impl<'outer, 'inner, S> Freeze for Optional<'outer, 'inner, S>

§

impl<'outer, 'inner, S> !RefUnwindSafe for Optional<'outer, 'inner, S>

§

impl<'outer, 'inner, S> !Send for Optional<'outer, 'inner, S>

§

impl<'outer, 'inner, S> !Sync for Optional<'outer, 'inner, S>

§

impl<'outer, 'inner, S> Unpin for Optional<'outer, 'inner, S>
where S: Unpin,

§

impl<'outer, 'inner, S> UnsafeUnpin for Optional<'outer, 'inner, S>

§

impl<'outer, 'inner, S> !UnwindSafe for Optional<'outer, 'inner, S>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V