aboutsummaryrefslogtreecommitdiffstats
path: root/lib/arel/engines/sql/relations/relation.rb
blob: 4cfb83a6017cd54f8652723699b2bf77dee9da70 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
module Arel
  class Relation
    def to_sql(formatter = Sql::SelectStatement.new(self))
      formatter.select select_sql, self
    end

    def select_sql
      build_query \
        "SELECT     #{select_clauses.join(', ')}",
        "FROM       #{table_sql(Sql::TableReference.new(self))}",
        (joins(self)                                   unless joins(self).blank? ),
        ("WHERE     #{where_clauses.join("\n\tAND ")}" unless wheres.blank?      ),
        ("GROUP BY  #{group_clauses.join(', ')}"       unless groupings.blank?   ),
        ("ORDER BY  #{order_clauses.join(', ')}"       unless orders.blank?      ),
        ("LIMIT     #{taken}"                          unless taken.blank?       ),
        ("OFFSET    #{skipped}"                        unless skipped.blank?     )
    end

    def inclusion_predicate_sql
      "IN"
    end

    def christener
      @christener ||= Sql::Christener.new
    end

  protected

    def build_query(*parts)
      parts.compact.join("\n")
    end

    def select_clauses
      attributes.collect { |a| a.to_sql(Sql::SelectClause.new(self)) }
    end

    def where_clauses
      wheres.collect { |w| w.to_sql(Sql::WhereClause.new(self)) }
    end

    def group_clauses
      groupings.collect { |g| g.to_sql(Sql::GroupClause.new(self)) }
    end

    def order_clauses
      orders.collect { |o| o.to_sql(Sql::OrderClause.new(self)) }
    end

  end
end