Skip to main content

SqliteValue

Struct SqliteValue 

Source
pub struct SqliteValue(/* private fields */);
Available on crate feature _sqlite only.
Expand description

An owned handle to a sqlite3_value.

ยงNote: Decoding is Stateful

The sqlite3_value interface reserves the right to be stateful:

Other interfaces might change the datatype for an sqlite3_value object. For example, if the datatype is initially SQLITE_INTEGER and sqlite3_value_text(V) is called to extract a text value for that integer, then subsequent calls to sqlite3_value_type(V) might return SQLITE_TEXT. Whether or not a persistent internal datatype conversion occurs is undefined and may change from one release of SQLite to the next.

Thus, this type is !Sync and SqliteValueRef is !Send and !Sync to prevent data races.

Additionally, this statefulness means that the return values of sqlite3_value_bytes() and sqlite3_value_blob() could be invalidated by later calls to other sqlite3_value* methods.

To prevent undefined behavior from accessing dangling pointers, this type (and any SqliteValueRef instances created from it) remembers when it was used to decode a borrowed &[u8] or &str and returns an error if it is used to decode any other type.

To bypass this error, you must prove that no outstanding borrows exist.

This may be done in one of a few ways:

This is only necessary if using the same SqliteValue or SqliteValueRef to decode multiple different types. The vast majority of use-cases employing once-through decoding should not have to worry about this.

Implementationsยง

Sourceยง

impl SqliteValue

Source

pub fn reset_borrow(&mut self)

Prove that there are no outstanding borrows of this instance.

Call this after decoding a borrowed &[u8] or &str to reset the internal borrowed state and allow decoding of other types.

Source

pub fn try_clone(&self) -> Result<SqliteValue, SqliteError>

Call sqlite3_value_dup() to create a new instance of this type.

Returns an error if the call returns a null pointer, indicating that SQLite was unable to allocate the additional memory required.

Non-panicking version of Self::clone().

Trait Implementationsยง

Sourceยง

impl Clone for SqliteValue

Sourceยง

fn clone(&self) -> SqliteValue

Call sqlite3_value_dup() to create a new instance of this type.

ยงPanics

If sqlite3_value_dup() returns a null pointer, indicating an out-of-memory condition.

See Self::try_clone() for a non-panicking version.

1.0.0 ยท Sourceยง

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Sourceยง

impl Value for SqliteValue

Sourceยง

type Database = Sqlite

Sourceยง

fn as_ref(&self) -> SqliteValueRef<'_>

Get this value as a reference.
Sourceยง

fn type_info(&self) -> Cow<'_, SqliteTypeInfo>

Get the type information for this value.
Sourceยง

fn is_null(&self) -> bool

Returns true if the SQL value is NULL.
Sourceยง

fn decode<'r, T>(&'r self) -> T
where T: Decode<'r, Self::Database> + Type<Self::Database>,

Decode this single value into the requested type. Read more
Sourceยง

fn decode_unchecked<'r, T>(&'r self) -> T
where T: Decode<'r, Self::Database>,

Decode this single value into the requested type. Read more
Sourceยง

fn try_decode<'r, T>(&'r self) -> Result<T, Error>
where T: Decode<'r, Self::Database> + Type<Self::Database>,

Decode this single value into the requested type. Read more
Sourceยง

fn try_decode_unchecked<'r, T>(&'r self) -> Result<T, Error>
where T: Decode<'r, Self::Database>,

Decode this single value into the requested type. Read more

Auto Trait Implementationsยง

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> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dest: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

Sourceยง

impl<T> Instrument for T

Sourceยง

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Sourceยง

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Sourceยง

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 more
Sourceยง

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> โ“˜
where F: FnOnce(&Self) -> bool,

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
Sourceยง

impl<T> Same for T

Sourceยง

type Output = T

Should always be Self
Sourceยง

impl<T> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
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

Sourceยง

impl<T> WithSubscriber for T

Sourceยง

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Sourceยง

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more