module ActiveRecordLite module Base def fetch_lite(*select_sql) select_columns, columns = prepare(select_sql) _struct = Struct.new(*columns) sql = select(select_columns).to_sql self.connection.select_all(sql).map { |result| _struct.new(*result.values) } end def pluck_first(attribute) order(attribute).pluck(attribute).first end def pluck_last(attribute) order(attribute).pluck(attribute).last end private def prepare(select_sql) first_key = select_sql[0] if first_key.is_a?(Hash) prepare_hash(first_key) else [select_sql, select_sql] end end def prepare_hash(select_sql) columns = select_sql.keys select_columns = select_sql.map { |key, value| "#{value} AS #{key}" }.join(",") [select_columns, columns] end end end