1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/lib/active_relation/sql.rb
2008-03-16 15:40:15 -07:00

80 lines
No EOL
1.8 KiB
Ruby

module ActiveRelation
module Sql
module Quoting
delegate :quote_table_name, :quote_column_name, :quote, :to => :engine
end
class Formatter
attr_reader :engine
include Quoting
def initialize(engine)
@engine = engine
end
end
class SelectExpression < Formatter
def attribute(relation_name, attribute_name, aliaz)
"#{quote_table_name(relation_name)}.#{quote_column_name(attribute_name)}" + (aliaz ? " AS #{quote(aliaz.to_s)}" : "")
end
def select(select_sql, aliaz)
"(#{select_sql})" + (aliaz ? " AS #{quote(aliaz)}" : "")
end
end
class WhereClause < Formatter
def value(value)
value
end
end
class WhereCondition < Formatter
def attribute(relation_name, attribute_name, aliaz)
"#{quote_table_name(relation_name)}.#{quote_column_name(attribute_name)}"
end
def value(value, column = nil)
quote(value, column)
end
def select(select_sql, aliaz)
"(#{select_sql})"
end
end
class SelectStatement < Formatter
def select(select_sql, aliaz)
select_sql
end
end
class TableReference < Formatter
def select(select_sql, aliaz)
"(#{select_sql}) AS #{quote_table_name(aliaz)}"
end
end
class Attribute < WhereCondition
def initialize(attribute)
@attribute, @engine = attribute, attribute.engine
end
def value(value)
value.to_sql(self)
end
def scalar(scalar)
quote(scalar, @attribute.column)
end
def array(array)
"(" + array.collect { |e| e.to_sql(self) }.join(', ') + ")"
end
end
class Value < WhereCondition
end
end
end