1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/lib/arel/table.rb
2010-09-07 16:07:37 -07:00

75 lines
1.5 KiB
Ruby

module Arel
class Table
include Arel::Crud
@engine = nil
class << self; attr_accessor :engine; end
attr_reader :name, :engine, :aliases, :table_alias
def initialize name, engine = Table.engine
@name = name
@engine = engine
@engine = engine[:engine] if Hash === engine
@columns = nil
@aliases = []
@table_alias = nil
end
def alias
Nodes::TableAlias.new("#{name}_2", self).tap do |node|
@aliases << node
end
end
def tm
SelectManager.new(@engine).from(self)
end
def joins manager
nil
end
def join relation, klass = Nodes::InnerJoin
sm = SelectManager.new(@engine)
case relation
when String, Nodes::SqlLiteral
raise if relation.blank?
sm.from Nodes::StringJoin.new(self, relation)
else
sm.from klass.new(self, relation, nil)
end
end
def group *columns
tm.group(*columns)
end
def order *expr
tm.order(*expr)
end
def where condition
tm.where condition
end
def project thing
tm.project thing
end
def take amount
tm.take amount
end
def columns
@columns ||= @engine.connection.columns(@name, "#{@name} Columns").map do |column|
Attributes.for(column).new self, column.name, column
end
end
def [] name
name = name.to_s
columns.find { |column| column.name == name }
end
end
end