Skip to main content

SelectStatement

Struct SelectStatement 

Source
pub struct SelectStatement { /* private fields */ }
Expand description

SELECT statement builder

This struct provides a fluent API for constructing SELECT queries.

§Examples

use reinhardt_query::prelude::*;

let query = Query::select()
    .column(Expr::col("id"))
    .column(Expr::col("name"))
    .from("users")
    .and_where(Expr::col("active").eq(true))
    .order_by("name", Order::Asc)
    .limit(10);

Implementations§

Source§

impl SelectStatement

Source

pub fn new() -> Self

Create a new SELECT statement

Source

pub fn take(&mut self) -> Self

Take the ownership of data in the current SelectStatement

Source

pub fn column<C>(&mut self, col: C) -> &mut Self
where C: IntoColumnRef,

Add a column to the SELECT clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .column("id")
    .column("name")
    .from("users");
Source

pub fn columns<I, C>(&mut self, cols: I) -> &mut Self
where I: IntoIterator<Item = C>, C: IntoColumnRef,

Add multiple columns to the SELECT clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .columns(["id", "name", "email"])
    .from("users");
Source

pub fn expr<E>(&mut self, expr: E) -> &mut Self
where E: Into<SimpleExpr>,

Add an expression to the SELECT clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .expr(Expr::col("price").mul(Expr::col("quantity")))
    .from("orders");
Source

pub fn expr_as<E, A>(&mut self, expr: E, alias: A) -> &mut Self
where E: Into<SimpleExpr>, A: IntoIden,

Add an expression with an alias to the SELECT clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .expr_as(Expr::col("price").mul(Expr::col("quantity")), "total")
    .from("orders");
Source

pub fn from<T>(&mut self, tbl: T) -> &mut Self
where T: IntoTableRef,

Add a table to the FROM clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .column("id")
    .from("users");
Source

pub fn from_as<T, A>(&mut self, tbl: T, alias: A) -> &mut Self
where T: IntoIden, A: IntoIden,

Add a table with alias to the FROM clause

Equivalent to FROM table AS alias.

Source

pub fn from_subquery( &mut self, query: SelectStatement, alias: impl IntoIden, ) -> &mut Self

Add a subquery to the FROM clause

Equivalent to FROM (SELECT ...) AS alias.

Source

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

Clear all column selections

Source

pub fn join<T, C>(&mut self, join: JoinType, tbl: T, condition: C) -> &mut Self

Add a JOIN clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .from("users")
    .join(
        JoinType::InnerJoin,
        "orders",
        Expr::col(("users", "id")).equals(("orders", "user_id"))
    );
Source

pub fn left_join<T, C>(&mut self, tbl: T, condition: C) -> &mut Self

Add a LEFT JOIN clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .from("users")
    .left_join(
        "orders",
        Expr::col(("users", "id")).equals(("orders", "user_id"))
    );
Source

pub fn right_join<T, C>(&mut self, tbl: T, condition: C) -> &mut Self

Add a RIGHT JOIN clause

Source

pub fn full_outer_join<T, C>(&mut self, tbl: T, condition: C) -> &mut Self

Add a FULL OUTER JOIN clause

Source

pub fn inner_join<T, C>(&mut self, tbl: T, condition: C) -> &mut Self

Add an INNER JOIN clause

Source

pub fn cross_join<T>(&mut self, tbl: T) -> &mut Self
where T: IntoTableRef,

Add a CROSS JOIN clause

Source

pub fn and_where<C>(&mut self, condition: C) -> &mut Self
where C: IntoCondition,

Add a condition to the WHERE clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .from("users")
    .and_where(Expr::col("active").eq(true));
Source

pub fn cond_where(&mut self, condition: Condition) -> &mut Self

Add a condition to the WHERE clause using Condition

Source

pub fn group_by<C>(&mut self, col: C) -> &mut Self
where C: IntoColumnRef,

Add a GROUP BY clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .column("category")
    .expr_as(Expr::count("*"), "count")
    .from("products")
    .group_by("category");
Source

pub fn group_by_col<C>(&mut self, col: C) -> &mut Self
where C: IntoColumnRef,

Add a column to the GROUP BY clause (alias for group_by)

Source

pub fn group_by_columns<I, C>(&mut self, cols: I) -> &mut Self
where I: IntoIterator<Item = C>, C: IntoColumnRef,

Add multiple GROUP BY columns

Source

pub fn and_having<C>(&mut self, condition: C) -> &mut Self
where C: IntoCondition,

Add a condition to the HAVING clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .column("category")
    .expr_as(Expr::count("*"), "count")
    .from("products")
    .group_by("category")
    .and_having(Expr::count("*").gt(5));
Source

pub fn cond_having(&mut self, condition: Condition) -> &mut Self

Add a condition to the HAVING clause using Condition

Source

pub fn order_by<C>(&mut self, col: C, order: Order) -> &mut Self
where C: IntoColumnRef,

Add an ORDER BY clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .from("users")
    .order_by("name", Order::Asc)
    .order_by("created_at", Order::Desc);
Source

pub fn order_by_expr<E>(&mut self, expr: E, order: Order) -> &mut Self
where E: Into<SimpleExpr>,

Add an ORDER BY clause with expression

Source

pub fn limit<V>(&mut self, limit: V) -> &mut Self
where V: IntoValue,

Set the LIMIT clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .from("users")
    .limit(10);
Source

pub fn offset<V>(&mut self, offset: V) -> &mut Self
where V: IntoValue,

Set the OFFSET clause

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .from("users")
    .limit(10)
    .offset(20);
Source

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

Set DISTINCT

§Examples
use reinhardt_query::prelude::*;

let query = Query::select()
    .distinct()
    .column("category")
    .from("products");
Source

pub fn distinct_on<I, C>(&mut self, cols: I) -> &mut Self
where I: IntoIterator<Item = C>, C: IntoColumnRef,

Set DISTINCT ON (PostgreSQL only)

Source

pub fn union(&mut self, query: SelectStatement) -> &mut Self

Add a UNION clause

Source

pub fn union_all(&mut self, query: SelectStatement) -> &mut Self

Add a UNION ALL clause

Source

pub fn intersect(&mut self, query: SelectStatement) -> &mut Self

Add an INTERSECT clause

Source

pub fn except(&mut self, query: SelectStatement) -> &mut Self

Add an EXCEPT clause

Source

pub fn with_cte<N>(&mut self, name: N, query: SelectStatement) -> &mut Self
where N: IntoIden,

Add a Common Table Expression (CTE) to the WITH clause

§Examples
use reinhardt_query::prelude::*;

let cte = Query::select()
    .column("id")
    .column("name")
    .from("users")
    .and_where(Expr::col("active").eq(true));

let query = Query::select()
    .with_cte("active_users", cte)
    .column("*")
    .from("active_users");
Source

pub fn with_recursive_cte<N>( &mut self, name: N, query: SelectStatement, ) -> &mut Self
where N: IntoIden,

Add a RECURSIVE Common Table Expression (CTE) to the WITH clause

§Examples
use reinhardt_query::prelude::*;

// Recursive CTE for hierarchical data
let cte = Query::select()
    .column("id")
    .column("parent_id")
    .column("name")
    .from("categories")
    .and_where(Expr::col("parent_id").is_null())
    .union_all(
        Query::select()
            .column(Expr::col(("c", "id")))
            .column(Expr::col(("c", "parent_id")))
            .column(Expr::col(("c", "name")))
            .from_as("categories", "c")
            .join(
                JoinType::InnerJoin,
                "category_tree",
                Expr::col(("c", "parent_id")).eq(Expr::col(("category_tree", "id")))
            )
    );

let query = Query::select()
    .with_recursive_cte("category_tree", cte)
    .column("*")
    .from("category_tree");
Source

pub fn window_as<T>(&mut self, name: T, window: WindowStatement) -> &mut Self
where T: IntoIden,

Add a named window specification to the WINDOW clause

Named windows can be referenced by window functions using OVER window_name.

§Examples
use reinhardt_query::prelude::*;
use reinhardt_query::types::window::WindowStatement;

let window = WindowStatement {
    partition_by: vec![Expr::col("department_id").into_simple_expr()],
    order_by: vec![OrderExpr {
        expr: Expr::col("salary").into_simple_expr(),
        order: Order::Desc,
        nulls: None,
    }],
    frame: None,
};

let query = Query::select()
    .column("name")
    .expr_as(Expr::row_number().over_named("w"), "rank")
    .from("employees")
    .window_as("w", window);
Source

pub fn lock(&mut self, lock_type: LockType) -> &mut Self

Set FOR UPDATE lock

Source

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

Set FOR UPDATE lock

Source

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

Set FOR SHARE lock

Source

pub fn apply_if<T, F>(&mut self, val: Option<T>, func: F) -> &mut Self
where F: FnOnce(&mut Self, T),

Apply a function conditionally

Source

pub fn conditions<T, F>( &mut self, b: bool, if_true: T, if_false: F, ) -> &mut Self
where T: FnOnce(&mut Self), F: FnOnce(&mut Self),

Conditional execution

Trait Implementations§

Source§

impl Clone for SelectStatement

Source§

fn clone(&self) -> SelectStatement

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for SelectStatement

Source§

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

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

impl Default for SelectStatement

Source§

fn default() -> SelectStatement

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

impl QueryStatementBuilder for SelectStatement

Source§

fn build_any(&self, query_builder: &dyn QueryBuilderTrait) -> (String, Values)

Build SQL statement for a database backend and collect query parameters Read more
Source§

fn to_string<T: QueryBuilderTrait>(&self, query_builder: T) -> String

Build SQL statement for a database backend and return SQL string with values inlined as SQL literals. Read more
Source§

fn build<T: QueryBuilderTrait>(&self, query_builder: T) -> (String, Values)

Build SQL statement with parameter collection Read more
Source§

impl QueryStatementWriter for SelectStatement

Auto Trait Implementations§

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.