diff options
author | Rafael França <rafaelmfranca@gmail.com> | 2017-03-27 18:21:41 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-27 18:21:41 -0400 |
commit | 3b474da4e6d623bf10b09bbb96b292c6dcf795af (patch) | |
tree | b4f8d1f2430cde9a94d1613bb38a9d14b324724e | |
parent | c1faca6333abe4b938b98fedc8d1f47b88209ecf (diff) | |
parent | e1533d2d5a631859ea47702ab64c11bba420b5b8 (diff) | |
download | rails-3b474da4e6d623bf10b09bbb96b292c6dcf795af.tar.gz rails-3b474da4e6d623bf10b09bbb96b292c6dcf795af.tar.bz2 rails-3b474da4e6d623bf10b09bbb96b292c6dcf795af.zip |
Merge pull request #28488 from kamipo/preprocess_association_query_handling
Preprocess association query handling in predicate builder
-rw-r--r-- | activerecord/lib/active_record/relation/predicate_builder.rb | 21 |
1 files changed, 8 insertions, 13 deletions
diff --git a/activerecord/lib/active_record/relation/predicate_builder.rb b/activerecord/lib/active_record/relation/predicate_builder.rb index 18ae10a652..fca914aedd 100644 --- a/activerecord/lib/active_record/relation/predicate_builder.rb +++ b/activerecord/lib/active_record/relation/predicate_builder.rb @@ -87,14 +87,19 @@ module ActiveRecord binds = [] attributes.each do |column_name, value| + binds.concat(value.bound_attributes) if value.is_a?(Relation) case when value.is_a?(Hash) && !table.has_column?(column_name) attrs, bvs = associated_predicate_builder(column_name).create_binds_for_hash(value) result[column_name] = attrs binds += bvs - next - when value.is_a?(Relation) - binds += value.bound_attributes + when table.associated_with?(column_name) + # Find the foreign key when using queries such as: + # Post.where(author: author) + # + # For polymorphic relationships, find the foreign key and type: + # PriceEstimate.where(estimate_of: treasure) + result[column_name] = AssociationQueryHandler.value_for(table, column_name, value) when value.is_a?(Range) && !table.type(column_name).respond_to?(:subtype) first = value.begin last = value.end @@ -114,15 +119,6 @@ module ActiveRecord binds << build_bind_param(column_name, value) end end - - # Find the foreign key when using queries such as: - # Post.where(author: author) - # - # For polymorphic relationships, find the foreign key and type: - # PriceEstimate.where(estimate_of: treasure) - if table.associated_with?(column_name) - result[column_name] = AssociationQueryHandler.value_for(table, column_name, value) - end end [result, binds] @@ -155,7 +151,6 @@ module ActiveRecord end def can_be_bound?(column_name, value) - return if table.associated_with?(column_name) case value when Array, Range table.type(column_name).respond_to?(:subtype) |