pub struct SelectManager<M: Arel> { /* private fields */ }

Implementations§

source§

impl<M: Arel> SelectManager<M>

source

pub fn select<T: AsRef<str>>(&mut self, columns: Vec<T>) -> &mut Self

Examples
use arel::prelude::*;
use arel::manager::SelectManager;
#[arel]
struct User {}
impl Arel for User {}
let mut select_manager = SelectManager::<User>::default();
assert_eq!(select_manager.to_sql().unwrap().to_sql_string().unwrap(), r#"SELECT "user".* FROM "user""#);

select_manager.select(vec!["id", "name"]);
assert_eq!(select_manager.to_sql().unwrap().to_sql_string().unwrap(), r#"SELECT "user"."id", "user"."name" FROM "user""#);
source

pub fn select_sql<S: Into<Sql>>(&mut self, sql: S) -> &mut Self

Examples
use arel::prelude::*;
use arel::manager::SelectManager;
#[arel]
struct User {}
impl Arel for User {}
let mut select_manager = SelectManager::<User>::default();
select_manager.select_sql("COUNT(*)");
assert_eq!(select_manager.to_sql().unwrap().to_sql_string().unwrap(), r#"SELECT COUNT(*) FROM "user""#);
source

pub fn distinct(&mut self) -> &mut Self

Examples
use arel::prelude::*;
use arel::manager::SelectManager;
#[arel]
struct User {}
impl Arel for User {}
let mut select_manager = SelectManager::<User>::default();
select_manager.distinct();
assert_eq!(select_manager.to_sql().unwrap().to_sql_string().unwrap(), r#"SELECT DISTINCT "user".* FROM "user""#);
source

pub fn join<U: Arel>(&mut self, join_type: JoinConst) -> &mut Self

Examples
use arel::prelude::*;
use arel::manager::SelectManager;
#[arel]
struct User {}
impl Arel for User {}
#[arel]
struct Wallet {}
impl Arel for Wallet {}
let mut select_manager = SelectManager::<User>::default();
select_manager.join::<Wallet>(arel::JoinConst::InnerJoin);
assert_eq!(select_manager.to_sql().unwrap().to_sql_string().unwrap(), r#"SELECT "user".* FROM "user" INNER JOIN "wallet" ON "user"."id" = "wallet"."user_id""#);
source

pub fn inner_join<U: Arel>(&mut self) -> &mut Self

source

pub fn left_join<U: Arel>(&mut self) -> &mut Self

source

pub fn join_sql<S: Into<Sql>>(&mut self, sql: S) -> &mut Self

Examples
use arel::prelude::*;
use arel::manager::SelectManager;
#[arel]
struct User {}
impl Arel for User {}
let mut select_manager = SelectManager::<User>::default();
select_manager.join_sql("LEFT JOIN wallet on user.id = wallet.user_id");
assert_eq!(select_manager.to_sql().unwrap().to_sql_string().unwrap(), r#"SELECT "user".* FROM "user" LEFT JOIN wallet on user.id = wallet.user_id"#);
source

pub fn where<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn Where<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn where_range<K: AsRef<str>, V: ToString, R: RangeBounds<V>>( &mut self, key: K, range: R ) -> &mut Self

source

pub fn where_sql<S: Into<Sql>>(&mut self, sql: S) -> &mut Self

source

pub fn where_not<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn where_or<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn group<T: AsRef<str>>(&mut self, columns: Vec<T>) -> &mut Self

source

pub fn having<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn having_sql<S: Into<Sql>>(&mut self, sql: S) -> &mut Self

source

pub fn having_not<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn having_or<K: AsRef<str>, V: Into<Value>>( &mut self, key: K, value: V ) -> &mut Self

source

pub fn order<T: AsRef<str>>( &mut self, column: T, sort_type: SortConst ) -> &mut Self

source

pub fn order_asc<T: AsRef<str>>(&mut self, column: T) -> &mut Self

source

pub fn order_desc<T: AsRef<str>>(&mut self, column: T) -> &mut Self

source

pub fn limit(&mut self, num: usize) -> &mut Self

source

pub fn offset(&mut self, num: usize) -> &mut Self

source

pub fn paginate(&mut self, page: usize, page_size: usize) -> &mut Self

source

pub fn lock(&mut self) -> &mut Self

source

pub fn to_sql(&self) -> Result<Sql>

source§

impl<M> SelectManager<M>
where for<'b> M: Send + Unpin + FromRow<'b, DatabaseRow> + Arel,

source

pub fn to_query_builder<'a>(&self) -> Result<QueryBuilder<'a>>

source

pub async fn fetch_count_with_exec<'a, E>(&self, executor: E) -> Result<i64>
where E: Executor<'a, Database = Database>,

source

pub async fn fetch_count(&self) -> Result<i64>

source

pub async fn fetch_one_as<T>(&self) -> Result<T>
where for<'b> T: Send + Unpin + FromRow<'b, DatabaseRow>,

source

pub async fn fetch_one_optional_as<T>(&self) -> Result<Option<T>>
where for<'b> T: Send + Unpin + FromRow<'b, DatabaseRow>,

source

pub async fn fetch_one(&self) -> Result<M>

source

pub async fn fetch_one_optional(&self) -> Result<Option<M>>

source

pub async fn fetch_all_as<T>(&self) -> Result<Vec<T>>
where for<'b> T: Send + Unpin + FromRow<'b, DatabaseRow>,

source

pub async fn fetch_all(&self) -> Result<Vec<M>>

Trait Implementations§

source§

impl<M: Debug + Arel> Debug for SelectManager<M>

source§

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

Formats the value using the given formatter. Read more
source§

impl<M: Arel> Default for SelectManager<M>

source§

fn default() -> Self

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

Auto Trait Implementations§

§

impl<M> !RefUnwindSafe for SelectManager<M>

§

impl<M> Send for SelectManager<M>

§

impl<M> Sync for SelectManager<M>
where M: Sync,

§

impl<M> Unpin for SelectManager<M>
where M: Unpin,

§

impl<M> !UnwindSafe for SelectManager<M>

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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

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> Same for T

§

type Output = T

Should always be Self
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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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