Struct gluesql_core::ast_builder::JoinNode
source · pub struct JoinNode<'a> { /* private fields */ }Implementations§
source§impl<'a> JoinNode<'a>
impl<'a> JoinNode<'a>
pub fn new<N: Into<PrevNode<'a>>>( prev_node: N, name: String, alias: Option<String>, join_operator_type: JoinOperatorType ) -> Self
pub fn on<T: Into<ExprNode<'a>>>(self, expr: T) -> JoinConstraintNode<'a>
pub fn join(self, table_name: &str) -> JoinNode<'a>
pub fn join_as(self, table_name: &str, alias: &str) -> JoinNode<'a>
pub fn left_join(self, table_name: &str) -> JoinNode<'a>
pub fn left_join_as(self, table_name: &str, alias: &str) -> JoinNode<'a>
pub fn hash_executor<T: Into<ExprNode<'a>>, U: Into<ExprNode<'a>>>( self, key_expr: T, value_expr: U ) -> HashJoinNode<'a>
pub fn project<T: Into<SelectItemList<'a>>>( self, select_items: T ) -> ProjectNode<'a>
pub fn group_by<T: Into<ExprList<'a>>>(self, expr_list: T) -> GroupByNode<'a>
pub fn offset<T: Into<ExprNode<'a>>>(self, expr: T) -> OffsetNode<'a>
pub fn limit<T: Into<ExprNode<'a>>>(self, expr: T) -> LimitNode<'a>
pub fn filter<T: Into<ExprNode<'a>>>(self, expr: T) -> FilterNode<'a>
pub fn order_by<T: Into<OrderByExprList<'a>>>( self, order_by_exprs: T ) -> OrderByNode<'a>
pub fn alias_as(self, table_alias: &'a str) -> TableFactorNode<'_>
pub fn prebuild_for_constraint(self) -> Result<JoinConstraintData>
pub fn prebuild_for_hash_join( self ) -> Result<(Select, TableFactor, JoinOperator)>
Trait Implementations§
Auto Trait Implementations§
impl<'a> RefUnwindSafe for JoinNode<'a>
impl<'a> Send for JoinNode<'a>
impl<'a> Sync for JoinNode<'a>
impl<'a> Unpin for JoinNode<'a>
impl<'a> UnwindSafe for JoinNode<'a>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more