aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record
diff options
context:
space:
mode:
authorYves Senn <yves.senn@gmail.com>2014-06-06 08:55:25 +0200
committerYves Senn <yves.senn@gmail.com>2014-06-06 08:56:29 +0200
commit01777079cd7a137dd26537a32c25dea306e96e5a (patch)
tree4b7053569b19df4c7e432997e2253e0ad9afadd7 /activerecord/lib/active_record
parentaa54c91a151b47656320b511b30f546180202458 (diff)
parent71c5d565b5b660c459966dabb99e491cbc7c2c99 (diff)
downloadrails-01777079cd7a137dd26537a32c25dea306e96e5a.tar.gz
rails-01777079cd7a137dd26537a32c25dea306e96e5a.tar.bz2
rails-01777079cd7a137dd26537a32c25dea306e96e5a.zip
Merge pull request #14971 from versioncontrol/#14785
Baseclass becomes! subclass
Diffstat (limited to 'activerecord/lib/active_record')
-rw-r--r--activerecord/lib/active_record/relation.rb9
1 files changed, 8 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/relation.rb b/activerecord/lib/active_record/relation.rb
index d92ff781ee..cef40be7ce 100644
--- a/activerecord/lib/active_record/relation.rb
+++ b/activerecord/lib/active_record/relation.rb
@@ -74,7 +74,14 @@ module ActiveRecord
def _update_record(values, id, id_was) # :nodoc:
substitutes, binds = substitute_values values
- um = @klass.unscoped.where(@klass.arel_table[@klass.primary_key].eq(id_was || id)).arel.compile_update(substitutes, @klass.primary_key)
+
+ scope = @klass.unscoped
+
+ if @klass.finder_needs_type_condition?
+ scope.unscope!(where: @klass.inheritance_column)
+ end
+
+ um = scope.where(@klass.arel_table[@klass.primary_key].eq(id_was || id)).arel.compile_update(substitutes, @klass.primary_key)
@klass.connection.update(
um,