Skip to main content

SetOpBuilder

Struct SetOpBuilder 

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

Fluent builder for UNION, INTERSECT, and EXCEPT set operations.

Created by the free functions union(), union_all(), intersect(), intersect_all(), except_(), except_all(), or the corresponding methods on SelectBuilder. Supports optional .order_by(), .limit(), and .offset() clauses applied to the combined result.

§Examples

use polyglot_sql::builder::*;

let sql = union_all(
    select(["id"]).from("a"),
    select(["id"]).from("b"),
)
.order_by(["id"])
.limit(10)
.to_sql();

Implementations§

Source§

impl SetOpBuilder

Source

pub fn order_by<I, E>(self, expressions: I) -> Self
where I: IntoIterator<Item = E>, E: IntoExpr,

Add an ORDER BY clause applied to the combined set operation result.

Expressions not already wrapped with .asc() or .desc() default to ascending order.

Source

pub fn limit(self, count: usize) -> Self

Restrict the combined set operation result to count rows.

Source

pub fn offset(self, count: usize) -> Self

Skip the first count rows from the combined set operation result.

Source

pub fn build(self) -> Expression

Consume this builder and produce the final set operation Expression AST node.

The returned expression is one of Expression::Union, Expression::Intersect, or Expression::Except depending on how the builder was created.

Source

pub fn to_sql(self) -> String

Consume this builder, generate, and return the SQL string.

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