Class: Sequel::SQL::JoinClause
- Inherits:
-
Expression
- Object
- Expression
- Sequel::SQL::JoinClause
- Defined in:
- lib/sequel/sql.rb
Overview
Represents an SQL JOIN clause, used for joining tables.
Direct Known Subclasses
Instance Attribute Summary collapse
-
#join_type ⇒ Object
readonly
The type of join to do.
-
#table_expr ⇒ Object
readonly
The expression representing the table/set related to the JOIN.
Instance Method Summary collapse
-
#column_aliases ⇒ Object
The column aliases to use for the JOIN , or nil if the JOIN does not use a derived column list.
-
#initialize(join_type, table_expr) ⇒ JoinClause
constructor
Create an object with the given join_type and table expression.
-
#table ⇒ Object
The table/set related to the JOIN, without any alias.
-
#table_alias ⇒ Object
The table alias to use for the JOIN , or nil if the JOIN does not alias the table.
Methods inherited from Expression
#==, attr_reader, #eql?, #hash, inherited, #inspect, #lit, #sql_literal
Constructor Details
#initialize(join_type, table_expr) ⇒ JoinClause
Create an object with the given join_type and table expression.
1535 1536 1537 1538 1539 |
# File 'lib/sequel/sql.rb', line 1535 def initialize(join_type, table_expr) @join_type = join_type @table_expr = table_expr freeze end |
Instance Attribute Details
#join_type ⇒ Object (readonly)
The type of join to do
1528 1529 1530 |
# File 'lib/sequel/sql.rb', line 1528 def join_type @join_type end |
#table_expr ⇒ Object (readonly)
The expression representing the table/set related to the JOIN. Is an AliasedExpression if the JOIN uses an alias.
1532 1533 1534 |
# File 'lib/sequel/sql.rb', line 1532 def table_expr @table_expr end |
Instance Method Details
#column_aliases ⇒ Object
The column aliases to use for the JOIN , or nil if the JOIN does not use a derived column list.
1560 1561 1562 1563 1564 |
# File 'lib/sequel/sql.rb', line 1560 def column_aliases if @table_expr.is_a?(AliasedExpression) @table_expr.columns end end |
#table ⇒ Object
The table/set related to the JOIN, without any alias.
1542 1543 1544 1545 1546 1547 1548 |
# File 'lib/sequel/sql.rb', line 1542 def table if @table_expr.is_a?(AliasedExpression) @table_expr.expression else @table_expr end end |
#table_alias ⇒ Object
The table alias to use for the JOIN , or nil if the JOIN does not alias the table.
1552 1553 1554 1555 1556 |
# File 'lib/sequel/sql.rb', line 1552 def table_alias if @table_expr.is_a?(AliasedExpression) @table_expr.alias end end |