Struct Element
pub struct Element {
pub uuid: Uuid,
pub updu: Option<Uuid>,
pub updt: Option<NaiveDateTime>,
pub ver: Option<i32>,
pub rstatus: Option<RStatus>,
pub name: String,
pub formula: String,
pub atomic_mass: f32,
pub phase: String,
pub density: Option<f32>,
pub properties: Option<Json<ElementProperties>>,
pub color: Option<String>,
}
Fields§
§uuid: Uuid
§updu: Option<Uuid>
§updt: Option<NaiveDateTime>
§ver: Option<i32>
§rstatus: Option<RStatus>
§name: String
§formula: String
§atomic_mass: f32
§phase: String
§density: Option<f32>
§properties: Option<Json<ElementProperties>>
§color: Option<String>
Implementations§
§impl Element
impl Element
pub fn from_request(element_request: &ElementRequest) -> Element
pub fn to_response(&self) -> ElementResponse
Trait Implementations§
§impl<'update> AsChangeset for &'update Element
impl<'update> AsChangeset for &'update Element
§type Changeset = <(Option<Eq<updu, <&'update Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'update NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'update i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<name, <&'update String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<formula, <&'update String as AsExpression<<formula as Expression>::SqlType>>::Expression>, Eq<atomic_mass, <&'update f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>, Eq<phase, <&'update String as AsExpression<<phase as Expression>::SqlType>>::Expression>, Option<Eq<density, <&'update f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <&'update Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <&'update String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as AsChangeset>::Changeset
type Changeset = <(Option<Eq<updu, <&'update Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'update NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'update i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'update RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<name, <&'update String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<formula, <&'update String as AsExpression<<formula as Expression>::SqlType>>::Expression>, Eq<atomic_mass, <&'update f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>, Eq<phase, <&'update String as AsExpression<<phase as Expression>::SqlType>>::Expression>, Option<Eq<density, <&'update f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <&'update Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <&'update String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as AsChangeset>::Changeset
The update statement this type represents
§fn as_changeset(self) -> Self::Changeset
fn as_changeset(self) -> Self::Changeset
Convert
self
into the actual update statement being executed§impl<'update> AsChangeset for Element
impl<'update> AsChangeset for Element
§type Changeset = <(Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<formula, <String as AsExpression<<formula as Expression>::SqlType>>::Expression>, Eq<atomic_mass, <f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>, Eq<phase, <String as AsExpression<<phase as Expression>::SqlType>>::Expression>, Option<Eq<density, <f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as AsChangeset>::Changeset
type Changeset = <(Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>, Eq<formula, <String as AsExpression<<formula as Expression>::SqlType>>::Expression>, Eq<atomic_mass, <f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>, Eq<phase, <String as AsExpression<<phase as Expression>::SqlType>>::Expression>, Option<Eq<density, <f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as AsChangeset>::Changeset
The update statement this type represents
§fn as_changeset(self) -> Self::Changeset
fn as_changeset(self) -> Self::Changeset
Convert
self
into the actual update statement being executed§impl<'de> Deserialize<'de> for Element
impl<'de> Deserialize<'de> for Element
§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
§impl<'ident> Identifiable for &'ident Element
impl<'ident> Identifiable for &'ident Element
§impl<'insert> Insertable<table> for &'insert Element
impl<'insert> Insertable<table> for &'insert Element
§type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <&'insert Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'insert NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'insert i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'insert String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<formula, <&'insert String as AsExpression<<formula as Expression>::SqlType>>::Expression>>, Option<Eq<atomic_mass, <&'insert f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>>, Option<Eq<phase, <&'insert String as AsExpression<<phase as Expression>::SqlType>>::Expression>>, Option<Eq<density, <&'insert f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <&'insert Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <&'insert String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
type Values = <(Option<Eq<uuid, <&'insert Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <&'insert Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <&'insert NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <&'insert i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <&'insert RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<name, <&'insert String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<formula, <&'insert String as AsExpression<<formula as Expression>::SqlType>>::Expression>>, Option<Eq<atomic_mass, <&'insert f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>>, Option<Eq<phase, <&'insert String as AsExpression<<phase as Expression>::SqlType>>::Expression>>, Option<Eq<density, <&'insert f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <&'insert Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <&'insert String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
The
VALUES
clause to insert these records Read moreSource§fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
Insert
self
into a given table. Read more§impl<'insert> Insertable<table> for Element
impl<'insert> Insertable<table> for Element
§type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<formula, <String as AsExpression<<formula as Expression>::SqlType>>::Expression>>, Option<Eq<atomic_mass, <f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>>, Option<Eq<phase, <String as AsExpression<<phase as Expression>::SqlType>>::Expression>>, Option<Eq<density, <f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
type Values = <(Option<Eq<uuid, <Uuid as AsExpression<<uuid as Expression>::SqlType>>::Expression>>, Option<Eq<updu, <Uuid as AsExpression<<updu as Expression>::SqlType>>::Expression>>, Option<Eq<updt, <NaiveDateTime as AsExpression<<updt as Expression>::SqlType>>::Expression>>, Option<Eq<ver, <i32 as AsExpression<<ver as Expression>::SqlType>>::Expression>>, Option<Eq<rstatus, <RStatus as AsExpression<<rstatus as Expression>::SqlType>>::Expression>>, Option<Eq<name, <String as AsExpression<<name as Expression>::SqlType>>::Expression>>, Option<Eq<formula, <String as AsExpression<<formula as Expression>::SqlType>>::Expression>>, Option<Eq<atomic_mass, <f32 as AsExpression<<atomic_mass as Expression>::SqlType>>::Expression>>, Option<Eq<phase, <String as AsExpression<<phase as Expression>::SqlType>>::Expression>>, Option<Eq<density, <f32 as AsExpression<<density as Expression>::SqlType>>::Expression>>, Option<Eq<properties, <Json<ElementProperties> as AsExpression<<properties as Expression>::SqlType>>::Expression>>, Option<Eq<color, <String as AsExpression<<color as Expression>::SqlType>>::Expression>>) as Insertable<table>>::Values
The
VALUES
clause to insert these records Read moreSource§fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
fn insert_into(self, table: T) -> InsertStatement<T, Self::Values>where
Self: Sized,
Insert
self
into a given table. Read more§impl MetaFields for Element
impl MetaFields for Element
fn update_fields(&mut self, user_id: Uuid)
fn init_fields(&mut self, user_id: Uuid)
§impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Element
impl<__DB: Backend, __ST> Queryable<__ST, __DB> for Element
§impl<__DB: Backend> QueryableByName<__DB> for Elementwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<updu>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
String: FromSql<SqlTypeOf<name>, __DB> + FromSql<SqlTypeOf<formula>, __DB> + FromSql<SqlTypeOf<phase>, __DB>,
f32: FromSql<SqlTypeOf<atomic_mass>, __DB>,
Option<f32>: FromSql<SqlTypeOf<density>, __DB>,
Option<Json<ElementProperties>>: FromSql<SqlTypeOf<properties>, __DB>,
Option<String>: FromSql<SqlTypeOf<color>, __DB>,
impl<__DB: Backend> QueryableByName<__DB> for Elementwhere
Uuid: FromSql<SqlTypeOf<uuid>, __DB>,
Option<Uuid>: FromSql<SqlTypeOf<updu>, __DB>,
Option<NaiveDateTime>: FromSql<SqlTypeOf<updt>, __DB>,
Option<i32>: FromSql<SqlTypeOf<ver>, __DB>,
Option<RStatus>: FromSql<SqlTypeOf<rstatus>, __DB>,
String: FromSql<SqlTypeOf<name>, __DB> + FromSql<SqlTypeOf<formula>, __DB> + FromSql<SqlTypeOf<phase>, __DB>,
f32: FromSql<SqlTypeOf<atomic_mass>, __DB>,
Option<f32>: FromSql<SqlTypeOf<density>, __DB>,
Option<Json<ElementProperties>>: FromSql<SqlTypeOf<properties>, __DB>,
Option<String>: FromSql<SqlTypeOf<color>, __DB>,
impl<'insert> UndecoratedInsertRecord<table> for Element
Auto Trait Implementations§
impl Freeze for Element
impl RefUnwindSafe for Element
impl Send for Element
impl Sync for Element
impl Unpin for Element
impl UnwindSafe for Element
Blanket Implementations§
Source§impl<Src, Scheme> ApproxFrom<Src, Scheme> for Srcwhere
Scheme: ApproxScheme,
impl<Src, Scheme> ApproxFrom<Src, Scheme> for Srcwhere
Scheme: ApproxScheme,
Source§fn approx_from(src: Src) -> Result<Src, <Src as ApproxFrom<Src, Scheme>>::Err>
fn approx_from(src: Src) -> Result<Src, <Src as ApproxFrom<Src, Scheme>>::Err>
Convert the given value into an approximately equivalent representation.
Source§impl<Dst, Src, Scheme> ApproxInto<Dst, Scheme> for Srcwhere
Dst: ApproxFrom<Src, Scheme>,
Scheme: ApproxScheme,
impl<Dst, Src, Scheme> ApproxInto<Dst, Scheme> for Srcwhere
Dst: ApproxFrom<Src, Scheme>,
Scheme: ApproxScheme,
Source§type Err = <Dst as ApproxFrom<Src, Scheme>>::Err
type Err = <Dst as ApproxFrom<Src, Scheme>>::Err
The error type produced by a failed conversion.
Source§fn approx_into(self) -> Result<Dst, <Src as ApproxInto<Dst, Scheme>>::Err>
fn approx_into(self) -> Result<Dst, <Src as ApproxInto<Dst, Scheme>>::Err>
Convert the subject into an approximately equivalent representation.
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T, Dst> ConvAsUtil<Dst> for T
impl<T, Dst> ConvAsUtil<Dst> for T
Source§impl<T> ConvUtil for T
impl<T> ConvUtil for T
Source§fn approx_as<Dst>(self) -> Result<Dst, Self::Err>where
Self: Sized + ApproxInto<Dst>,
fn approx_as<Dst>(self) -> Result<Dst, Self::Err>where
Self: Sized + ApproxInto<Dst>,
Approximate the subject to a given type with the default scheme.
Source§fn approx_as_by<Dst, Scheme>(self) -> Result<Dst, Self::Err>
fn approx_as_by<Dst, Scheme>(self) -> Result<Dst, Self::Err>
Approximate the subject to a given type with a specific scheme.
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<T> IntoSql for T
impl<T> IntoSql for T
Source§fn into_sql<T>(self) -> Self::Expressionwhere
Self: Sized + AsExpression<T>,
fn into_sql<T>(self) -> Self::Expressionwhere
Self: Sized + AsExpression<T>,
Convert
self
to an expression for Diesel’s query builder. Read moreSource§fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expressionwhere
&'a Self: AsExpression<T>,
fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expressionwhere
&'a Self: AsExpression<T>,
Convert
&self
to an expression for Diesel’s query builder. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self
is actually part of its subset T
(and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.