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, NotSpecialized> 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 HasBindCollector<'b>>::BindCollector, 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> !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 Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

const: unstable · 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 Twhere Conn: Connection<Backend = DB>, DB: Backend, T: QueryFragment<DB, NotSpecialized> + QueryId,

source§

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

Execute this command
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · 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::Expressionwhere Self: AsExpression<T> + Sized, T: SqlType + TypedExpressionType,

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>>::Expressionwhere &'a Self: AsExpression<T>, T: SqlType + TypedExpressionType,

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

impl<T> NullableExpressionMethods for Twhere 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 Twhere 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 Twhere 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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

source§

fn vzip(self) -> V