Skip to main content

Mutable

Struct Mutable 

Source
pub struct Mutable<'transaction, T: Table> { /* private fields */ }
Expand description

Mutable access to columns of a single table row.

The whole row is retrieved and can be inspected from Rust code. However, only rows that are not used in a #[unique] constraint can be updated directly by dereferencing Mutable.

To update columns with a unique constraint, you have to use Mutable::unique.

Implementations§

Source§

impl<'transaction, T: Table> Mutable<'transaction, T>

Source

pub fn into_table_row(self) -> TableRow<T>

Turn the Mutable into a TableRow.

This will end the lifetime of the Mutable, which is useful since Mutable does not have a non lexical lifetime, because of the Drop impl.

If you do not need the TableRow, then it is also possible to just call drop.

Source

pub fn unique<O>( &mut self, f: impl FnOnce(&mut <T::Mutable as Deref>::Target) -> O, ) -> Result<O, T::Conflict>

Update unique constraint columns.

When the update succeeds, this function returns Ok, when it fails it returns Err with one of three conflict types:

If any of the changes made inside the closure conflict with an existing row, then all changes made inside the closure are reverted.

If the closure panics, then all changes made inside the closure are also reverted. Applying those changes is not possible, as conflicts can not be reported if there is a panic.

Trait Implementations§

Source§

impl<'transaction, T: Table> Deref for Mutable<'transaction, T>

Source§

type Target = <T as Table>::Mutable

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl<'transaction, T: Table> DerefMut for Mutable<'transaction, T>

Source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
Source§

impl<'transaction, T: Table> Drop for Mutable<'transaction, T>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

fn pin_drop(self: Pin<&mut Self>)

🔬This is a nightly-only experimental API. (pin_ergonomics)
Execute the destructor for this type, but different to Drop::drop, it requires self to be pinned. Read more

Auto Trait Implementations§

§

impl<'transaction, T> !Freeze for Mutable<'transaction, T>

§

impl<'transaction, T> !RefUnwindSafe for Mutable<'transaction, T>

§

impl<'transaction, T> !Send for Mutable<'transaction, T>

§

impl<'transaction, T> !Sync for Mutable<'transaction, T>

§

impl<'transaction, T> Unpin for Mutable<'transaction, T>
where T: Unpin, <T as Table>::Mutable: Unpin,

§

impl<'transaction, T> UnsafeUnpin for Mutable<'transaction, T>
where <T as Table>::Mutable: UnsafeUnpin,

§

impl<'transaction, T> !UnwindSafe for Mutable<'transaction, T>

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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.