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>
impl<'outer, 'inner, S> Optional<'outer, 'inner, S>
Sourcepub fn and<T: EqTyp>(
&mut self,
col: impl IntoExpr<'inner, S, Typ = Option<T>>,
) -> Expr<'inner, S, T>
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);Sourcepub fn is_none(&self) -> Expr<'outer, S, bool>
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);Sourcepub fn is_some(&self) -> Expr<'outer, S, bool>
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);Sourcepub fn and_then<T: EqTyp>(
&self,
col: impl IntoExpr<'inner, S, Typ = Option<T>>,
) -> Expr<'outer, S, Option<T>>
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));Sourcepub fn then<T: EqTyp + 'outer>(
&self,
col: impl IntoExpr<'inner, S, Typ = T>,
) -> Expr<'outer, S, Option<T>>
pub fn then<T: EqTyp + 'outer>( &self, col: impl IntoExpr<'inner, S, Typ = T>, ) -> Expr<'outer, S, Option<T>>
Sourcepub fn then_select<Out: 'static>(
&self,
d: impl IntoSelect<'inner, S, Out = Out>,
) -> Select<'outer, S, Option<Out>>
pub fn then_select<Out: 'static>( &self, d: impl IntoSelect<'inner, S, Out = Out>, ) -> Select<'outer, S, Option<Out>>
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> 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