Enum InnerValue

Source
#[non_exhaustive]
pub enum InnerValue<'a> {
Show 17 variants Int64(i64), UInt64(u64), Float(f32), Double(f64), Char(&'a [u8]), Number(&'a str), Raw(&'a [u8]), Timestamp(&'a dpiTimestamp), IntervalDS(&'a dpiIntervalDS), IntervalYM(&'a dpiIntervalYM), Clob(*mut dpiLob), Blob(*mut dpiLob), Object(*mut dpiObject), Stmt(*mut dpiStmt), Boolean(bool), Rowid(*mut dpiRowid), Vector(*mut dpiVector),
}
Expand description

Raw data inside of SqlValue

When the data type of an enum variant field is a reference, the field refers to the internal buffer provided by ODPI-C.

It is intended to be used in the following case.

Assuming that you have a decimal class Decimal which has from_str and from_i64 methods and try to get Oralce numbers as the class without precision loss, you need to get the SQL value as String and convert it by from_str without using this type.

For example

for number_col_result in conn.query_as::<String>("select number_column from table_name", &[])? {
   let number_col = number_col_result?;
   let decimal_value = Decimal::from_str(&number_col);
}

Another example

impl FromSql for Decimal {
    fn from_sql(val: &SqlValue) -> Result<Decimal> {
        Ok(Decimal::from_str(&val.get::<String>()?))
    }
}
for decimal_value_result in conn.query_as::<Decimal>("select number_column from table_name", &[])? {
   let decimal_value = decimal_value_result?;
}

These codes are inefficient because String values are created just to be passed to from_str().

By using the InnerValue type, you can refer to the internal str value directly and avoid temporary memory allocation.

impl FromSql for Decimal {
    fn from_sql(val: &SqlValue) -> Result<Decimal> {
        match val.as_inner_value()? {
            InnerValue::Int64(val) => Ok(Decimal::from_i64(val)),
            InnerValue::Number(val) => Decimal::from_str(val).map_err(|err|
               Error::with_source(ErrorKind::InvalidTypeConversion, err)
            ),
            _ => Err(Error::new(
                ErrorKind::InvalidTypeConversion,
                format!("Cannot convert {} to Decimal", val.oracle_type()?)
            )),
        }
    }
}
for decimal_value_result in conn.query_as::<Decimal>("select number_column from table_name", &[])? {
   let decimal_value = decimal_value_result?;
}

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Int64(i64)

§

UInt64(u64)

§

Float(f32)

§

Double(f64)

§

Char(&'a [u8])

§

Number(&'a str)

§

Raw(&'a [u8])

§

Timestamp(&'a dpiTimestamp)

§

IntervalDS(&'a dpiIntervalDS)

§

IntervalYM(&'a dpiIntervalYM)

§

Clob(*mut dpiLob)

§

Blob(*mut dpiLob)

§

Object(*mut dpiObject)

§

Stmt(*mut dpiStmt)

§

Boolean(bool)

§

Rowid(*mut dpiRowid)

§

Vector(*mut dpiVector)

Trait Implementations§

Source§

impl<'a> Clone for InnerValue<'a>

Source§

fn clone(&self) -> InnerValue<'a>

Returns a copy of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for InnerValue<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for InnerValue<'a>

§

impl<'a> RefUnwindSafe for InnerValue<'a>

§

impl<'a> !Send for InnerValue<'a>

§

impl<'a> !Sync for InnerValue<'a>

§

impl<'a> Unpin for InnerValue<'a>

§

impl<'a> UnwindSafe for InnerValue<'a>

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, 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> 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.