Skip to content

Commit

Permalink
adding bind values to the manager object
Browse files Browse the repository at this point in the history
  • Loading branch information
tenderlove committed Jan 13, 2014
1 parent 3086881 commit 9b5d603
Show file tree
Hide file tree
Showing 5 changed files with 11 additions and 9 deletions.
Expand Up @@ -67,12 +67,9 @@ def join_constraints(foreign_table, foreign_klass, node, join_type, tables, scop
left.merge right
end

if rel
if rel && !rel.arel.constraints.empty?
bind_values.concat rel.bind_values

if !rel.arel.constraints.empty?
constraint = constraint.and rel.arel.constraints
end
constraint = constraint.and rel.arel.constraints
end

joins << table.create_join(table, table.create_on(constraint), join_type)
Expand Down
2 changes: 1 addition & 1 deletion activerecord/lib/active_record/relation.rb
Expand Up @@ -608,7 +608,7 @@ def inspect
private

def exec_queries
@records = eager_loading? ? find_with_associations : @klass.find_by_sql(arel, bind_values)
@records = eager_loading? ? find_with_associations : @klass.find_by_sql(arel, arel.bind_values + bind_values)

preload = preload_values
preload += includes_values unless eager_loading?
Expand Down
6 changes: 5 additions & 1 deletion activerecord/lib/active_record/relation/calculations.rb
Expand Up @@ -235,11 +235,14 @@ def execute_simple_calculation(operation, column_name, distinct) #:nodoc:

column_alias = column_name

bind_values = nil

if operation == "count" && (relation.limit_value || relation.offset_value)
# Shortcut when limit is zero.
return 0 if relation.limit_value == 0

query_builder = build_count_subquery(relation, column_name, distinct)
bind_values = relation.bind_values
else
column = aggregate_column(column_name)

Expand All @@ -249,9 +252,10 @@ def execute_simple_calculation(operation, column_name, distinct) #:nodoc:
relation.select_values = [select_value]

query_builder = relation.arel
bind_values = query_builder.bind_values + relation.bind_values
end

result = @klass.connection.select_all(query_builder, nil, relation.bind_values)
result = @klass.connection.select_all(query_builder, nil, bind_values)
row = result.first
value = row && row.values.first
column = result.column_types.fetch(column_alias) do
Expand Down
3 changes: 2 additions & 1 deletion activerecord/lib/active_record/relation/finder_methods.rb
Expand Up @@ -255,7 +255,8 @@ def find_with_associations
if ActiveRecord::NullRelation === relation
[]
else
rows = connection.select_all(relation.arel, 'SQL', relation.bind_values.dup)
arel = relation.arel
rows = connection.select_all(arel, 'SQL', arel.bind_values + relation.bind_values)
join_dependency.instantiate(rows, aliases)
end
end
Expand Down
2 changes: 1 addition & 1 deletion activerecord/lib/active_record/relation/query_methods.rb
Expand Up @@ -1010,7 +1010,7 @@ def build_joins(manager, joins)

join_infos.each do |info|
info.joins.each { |join| manager.from(join) }
self.bind_values += info.binds
manager.bind_values.concat info.binds
end

manager.join_sources.concat(join_list)
Expand Down

0 comments on commit 9b5d603

Please sign in to comment.