aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--activerecord/lib/active_record/associations/class_methods/join_dependency/join_association.rb10
-rw-r--r--activerecord/lib/active_record/relation/query_methods.rb2
2 files changed, 9 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/associations/class_methods/join_dependency/join_association.rb b/activerecord/lib/active_record/associations/class_methods/join_dependency/join_association.rb
index 98536d23bc..4839068f6d 100644
--- a/activerecord/lib/active_record/associations/class_methods/join_dependency/join_association.rb
+++ b/activerecord/lib/active_record/associations/class_methods/join_dependency/join_association.rb
@@ -135,9 +135,15 @@ module ActiveRecord
conditions << process_conditions(options[:conditions], aliased_table_name)
end
- join = relation.join(target_table, join_type)
+ ands = relation.create_and(conditions)
- join.on(*conditions)
+ join = relation.create_join(
+ relation.froms.first,
+ target_table,
+ relation.create_on(ands),
+ join_type)
+
+ relation.from join
end
def join_has_and_belongs_to_many_to(relation)
diff --git a/activerecord/lib/active_record/relation/query_methods.rb b/activerecord/lib/active_record/relation/query_methods.rb
index dce9ac4808..51a39be065 100644
--- a/activerecord/lib/active_record/relation/query_methods.rb
+++ b/activerecord/lib/active_record/relation/query_methods.rb
@@ -266,7 +266,7 @@ module ActiveRecord
# FIXME: refactor this to build an AST
join_dependency.join_associations.each do |association|
- manager = association.join_to(manager)
+ association.join_to(manager)
end
return manager unless join_ast