Struct diesel_dynamic_schema::DynamicSelectClause

source ·
pub struct DynamicSelectClause<'a, DB, QS> { /* private fields */ }
Expand description

Represents a dynamically sized select clause

Implementations§

source§

impl<'a, DB, QS> DynamicSelectClause<'a, DB, QS>

source

pub fn new() -> Self

Constructs a new dynamically sized select clause without any fields

source

pub fn add_field<F>(&mut self, field: F)
where F: QueryFragment<DB> + SelectableExpression<QS> + NonAggregate + Send + 'a, DB: Backend,

Adds the field to the dynamically sized select clause

Trait Implementations§

source§

impl<'a, DB, QS> Default for DynamicSelectClause<'a, DB, QS>

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl<'a, QS, DB> Expression for DynamicSelectClause<'a, DB, QS>

§

type SqlType = Untyped

The type that this expression represents in SQL
source§

impl<'a, DB, QS> QueryFragment<DB> for DynamicSelectClause<'a, DB, QS>
where DB: Backend,

source§

fn walk_ast<'b>(&'b self, pass: AstPass<'_, 'b, DB>) -> QueryResult<()>

Walk over this QueryFragment for all passes. Read more
source§

fn to_sql( &self, out: &mut <DB as Backend>::QueryBuilder, backend: &DB ) -> Result<(), Error>

Available on crate feature i-implement-a-third-party-backend-and-opt-into-breaking-changes only.
Converts this QueryFragment to its SQL representation. Read more
source§

fn collect_binds<'b>( &'b self, out: &mut <DB as Backend>::BindCollector<'b>, metadata_lookup: &mut <DB as TypeMetadata>::MetadataLookup, backend: &'b DB ) -> Result<(), Error>

Available on crate feature i-implement-a-third-party-backend-and-opt-into-breaking-changes only.
Serializes all bind parameters in this query. Read more
source§

fn is_safe_to_cache_prepared(&self, backend: &DB) -> Result<bool, Error>

Available on crate feature i-implement-a-third-party-backend-and-opt-into-breaking-changes only.
Is this query safe to store in the prepared statement cache? Read more
source§

fn is_noop(&self, backend: &DB) -> Result<bool, Error>

Available on crate feature i-implement-a-third-party-backend-and-opt-into-breaking-changes only.
Does walking this AST have any effect?
source§

impl<'a, DB, QS> QueryId for DynamicSelectClause<'a, DB, QS>

source§

const HAS_STATIC_QUERY_ID: bool = false

Can the SQL generated by Self be uniquely identified by its type? Read more
§

type QueryId = ()

A type which uniquely represents Self in a SQL query. Read more
source§

fn query_id() -> Option<TypeId>

Returns the type id of Self::QueryId if Self::HAS_STATIC_QUERY_ID. Returns None otherwise. Read more
source§

impl<'a, DB, QS> ValidGrouping<()> for DynamicSelectClause<'a, DB, QS>

§

type IsAggregate = No

Is this expression aggregate? Read more
source§

impl<'a, DB, QS> AppearsOnTable<QS> for DynamicSelectClause<'a, DB, QS>
where Self: Expression,

source§

impl<'a, DB, QS> SelectableExpression<QS> for DynamicSelectClause<'a, DB, QS>
where Self: AppearsOnTable<QS>,

Auto Trait Implementations§

§

impl<'a, DB, QS> Freeze for DynamicSelectClause<'a, DB, QS>

§

impl<'a, DB, QS> !RefUnwindSafe for DynamicSelectClause<'a, DB, QS>

§

impl<'a, DB, QS> Send for DynamicSelectClause<'a, DB, QS>
where QS: Send,

§

impl<'a, DB, QS> !Sync for DynamicSelectClause<'a, DB, QS>

§

impl<'a, DB, QS> Unpin for DynamicSelectClause<'a, DB, QS>
where QS: Unpin,

§

impl<'a, DB, QS> !UnwindSafe for DynamicSelectClause<'a, DB, QS>

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<Conn, DB, T> ExecuteDsl<Conn, DB> for T
where Conn: Connection<Backend = DB>, DB: Backend, T: QueryFragment<DB> + QueryId,

source§

fn execute(query: T, conn: &mut Conn) -> Result<usize, Error>

Execute this command
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> IntoSql for T

source§

fn into_sql<T>(self) -> Self::Expression

Convert self to an expression for Diesel’s query builder. Read more
source§

fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression

Convert &self to an expression for Diesel’s query builder. Read more
source§

impl<T> NullableExpressionMethods for T
where T: Expression,

source§

fn nullable(self) -> Nullable<Self>

Converts this potentially non-null expression into one which is treated as nullable. This method has no impact on the generated SQL, and is only used to allow certain comparisons that would otherwise fail to compile. Read more
source§

fn assume_not_null(self) -> AssumeNotNull<Self>

Converts this potentially nullable expression into one which will be assumed to be not-null. This method has no impact on the generated SQL, however it will enable you to attempt deserialization of the returned value in a non-Option. Read more
source§

impl<T> PgExpressionMethods for T
where T: Expression,

source§

fn is_not_distinct_from<T>( self, other: T ) -> Grouped<IsNotDistinctFrom<Self, <T as AsExpression<Self::SqlType>>::Expression>>
where Self::SqlType: SqlType, T: AsExpression<Self::SqlType>,

Creates a PostgreSQL IS NOT DISTINCT FROM expression. Read more
source§

fn is_distinct_from<T>( self, other: T ) -> Grouped<IsDistinctFrom<Self, <T as AsExpression<Self::SqlType>>::Expression>>
where Self::SqlType: SqlType, T: AsExpression<Self::SqlType>,

Creates a PostgreSQL IS DISTINCT FROM expression. Read more
source§

impl<T> SqliteExpressionMethods for T
where T: Expression,

source§

fn is<T>( self, other: T ) -> Grouped<Is<Self, <T as AsExpression<Self::SqlType>>::Expression>>
where Self::SqlType: SqlType, T: AsExpression<Self::SqlType>,

Creates a Sqlite IS expression. Read more
source§

fn is_not<T>( self, other: T ) -> Grouped<IsNot<Self, <T as AsExpression<Self::SqlType>>::Expression>>
where Self::SqlType: SqlType, T: AsExpression<Self::SqlType>,

Creates a Sqlite IS NOT expression. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

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

§

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