module Bmg module Sql module SelectExp include Expr SELECT_DISTINCT = "SELECT DISTINCT".freeze SELECT = "SELECT".freeze def set_quantifier self[1] end def with_exp? false end def is_table_dee? from_clause.nil? && select_list.is_table_dee? end def distinct? set_quantifier.distinct? end def all? set_quantifier.all? end def has_computed_attributes? select_list.has_computed_attributes? end def join? from_clause && from_clause.join? end def should_be_reused? join? or distinct? or complex_clause? end def complex_clause? where_clause or order_by_clause or limit_clause or offset_clause end def select_exp self end def select_list self[2] end def is_select_star? self[2].first == :select_star end def where_clause find_child(:where_clause) end def predicate where_clause && where_clause.predicate end def from_clause find_child(:from_clause) end def table_spec from_clause.table_spec end def group_by_clause find_child(:group_by_clause) end def order_by_clause find_child(:order_by_clause) end def limit_clause find_child(:limit_clause) end def offset_clause find_child(:offset_clause) end def desaliaser(*args, &bl) select_list.desaliaser(*args, &bl) end ### to_xxx def to_attr_list select_list.to_attr_list end ### to_sql def to_sql(buffer, dialect, parenthesize = !buffer.empty?) if parenthesize sql_parenthesized(buffer){|b| to_sql(b, dialect, false) } else buffer << (distinct? ? SELECT_DISTINCT : SELECT) each_child(1) do |elm,i| buffer << SPACE elm.to_sql(buffer, dialect) end buffer end end end # module SelectExp end # module Sql end # module Bmg