aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb
diff options
context:
space:
mode:
Diffstat (limited to 'activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb')
-rw-r--r--activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb20
1 files changed, 8 insertions, 12 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb b/activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb
index 460745fba0..379ba162ed 100644
--- a/activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/mysql2_adapter.rb
@@ -584,18 +584,14 @@ module ActiveRecord
# in the form of a subsubquery. Ugh!
def join_to_update(update, select) #:nodoc:
if select.limit || select.offset || select.orders.any?
- subsubselect = select.ast.clone
- subsubselect.cores.last.projections = [update.ast.key]
- subsubselect = Arel::Nodes::TableAlias.new(
- Arel::Nodes::Grouping.new(subsubselect),
- '__active_record_temp'
- )
-
- subselect = Arel::Nodes::SelectCore.new
- subselect.from = subsubselect
- subselect.projections << Arel::Table.new('__active_record_temp')[update.ast.key.name]
-
- update.where update.ast.key.in(subselect)
+ subsubselect = select.clone
+ subsubselect.ast.cores.last.projections = [update.key]
+
+ subselect = Arel::SelectManager.new(select.engine)
+ subselect.project Arel.sql(update.key.name)
+ subselect.from subsubselect.as('__active_record_temp')
+
+ update.where update.key.in(subselect)
else
update.table select.ast.cores.last.source
update.wheres = select.constraints