aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/relation.rb
diff options
context:
space:
mode:
authorJon Leighton <j@jonathanleighton.com>2011-03-07 00:04:06 +0000
committerAaron Patterson <aaron.patterson@gmail.com>2011-03-07 08:51:17 -0800
commit532f915037ab65873c433e30399d11f93df9f1f8 (patch)
tree2d177e4d59e9ea66a3d0ac8ebf168967446cd64a /activerecord/lib/active_record/relation.rb
parent9cee693213e0205cb5992728bb516215e34cb79f (diff)
downloadrails-532f915037ab65873c433e30399d11f93df9f1f8.tar.gz
rails-532f915037ab65873c433e30399d11f93df9f1f8.tar.bz2
rails-532f915037ab65873c433e30399d11f93df9f1f8.zip
Referencing a table via the ON condition in a join should force that table to be eager-loaded via a JOIN rather than via subsequent queries.
Diffstat (limited to 'activerecord/lib/active_record/relation.rb')
-rw-r--r--activerecord/lib/active_record/relation.rb13
1 files changed, 12 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/relation.rb b/activerecord/lib/active_record/relation.rb
index f939bedc81..5af20bf38b 100644
--- a/activerecord/lib/active_record/relation.rb
+++ b/activerecord/lib/active_record/relation.rb
@@ -407,8 +407,19 @@ module ActiveRecord
private
def references_eager_loaded_tables?
+ joined_tables = arel.join_sources.map do |join|
+ if join.is_a?(Arel::Nodes::StringJoin)
+ tables_in_string(join.left)
+ else
+ [join.left.table_name, join.left.table_alias]
+ end
+ end
+
+ joined_tables += [table.name, table.table_alias]
+
# always convert table names to downcase as in Oracle quoted table names are in uppercase
- joined_tables = (tables_in_string(arel.join_sql) + [table.name, table.table_alias]).compact.map{ |t| t.downcase }.uniq
+ joined_tables = joined_tables.flatten.compact.map { |t| t.downcase }.uniq
+
(tables_in_string(to_sql) - joined_tables).any?
end