aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/associations/preloader/association.rb
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2012-04-19 06:26:13 -0700
committerJeremy Kemper <jeremy@bitsweat.net>2012-04-19 06:26:13 -0700
commitb9e5c5aca3313bd67b35a608c504175f99172d7f (patch)
tree5075061b731f1203dca6551cb1b696a246c916b6 /activerecord/lib/active_record/associations/preloader/association.rb
parent1166d49f62ccab789be208112163ad13183224e2 (diff)
parentebfa58abc895c0639211cb896a47b04e424322c8 (diff)
downloadrails-b9e5c5aca3313bd67b35a608c504175f99172d7f.tar.gz
rails-b9e5c5aca3313bd67b35a608c504175f99172d7f.tar.bz2
rails-b9e5c5aca3313bd67b35a608c504175f99172d7f.zip
Merge pull request #5898 from benedikt/3-2-stable
Readds the fix for #5667 and back ports the regression fix from #5718
Diffstat (limited to 'activerecord/lib/active_record/associations/preloader/association.rb')
-rw-r--r--activerecord/lib/active_record/associations/preloader/association.rb5
1 files changed, 3 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/associations/preloader/association.rb b/activerecord/lib/active_record/associations/preloader/association.rb
index 779f8164cc..ab50e43ea0 100644
--- a/activerecord/lib/active_record/associations/preloader/association.rb
+++ b/activerecord/lib/active_record/associations/preloader/association.rb
@@ -77,7 +77,7 @@ module ActiveRecord
# Some databases impose a limit on the number of ids in a list (in Oracle it's 1000)
# Make several smaller queries if necessary or make one query if the adapter supports it
sliced = owner_keys.each_slice(model.connection.in_clause_length || owner_keys.size)
- records = sliced.map { |slice| records_for(slice) }.flatten
+ records = sliced.map { |slice| records_for(slice).to_a }.flatten
end
# Each record may have multiple owners, and vice-versa
@@ -93,7 +93,8 @@ module ActiveRecord
end
def build_scope
- scope = klass.scoped
+ scope = klass.unscoped
+ scope.default_scoped = true
scope = scope.where(process_conditions(options[:conditions]))
scope = scope.where(process_conditions(preload_options[:conditions]))