diff options
author | Ryuta Kamizono <kamipo@gmail.com> | 2016-07-19 19:52:00 +0900 |
---|---|---|
committer | Ryuta Kamizono <kamipo@gmail.com> | 2016-07-19 20:06:58 +0900 |
commit | 3befc7a9ef4740fc4af5cc256e4c4589e0aea562 (patch) | |
tree | cac5518808fcd4db12934c11db7e3ffd11aac8f8 /activerecord/lib/active_record | |
parent | d8bc0964d29837407efe425d7a65ab9a27d96e82 (diff) | |
download | rails-3befc7a9ef4740fc4af5cc256e4c4589e0aea562.tar.gz rails-3befc7a9ef4740fc4af5cc256e4c4589e0aea562.tar.bz2 rails-3befc7a9ef4740fc4af5cc256e4c4589e0aea562.zip |
Use `connection#to_sql` for construct an SQL
Diffstat (limited to 'activerecord/lib/active_record')
-rw-r--r-- | activerecord/lib/active_record/relation.rb | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/activerecord/lib/active_record/relation.rb b/activerecord/lib/active_record/relation.rb index 93baa882ad..0792ba8f76 100644 --- a/activerecord/lib/active_record/relation.rb +++ b/activerecord/lib/active_record/relation.rb @@ -1,5 +1,3 @@ -require "arel/collectors/bind" - module ActiveRecord # = Active Record \Relation class Relation @@ -597,19 +595,16 @@ module ActiveRecord # # => SELECT "users".* FROM "users" WHERE "users"."name" = 'Oscar' def to_sql @to_sql ||= begin - relation = self - connection = klass.connection - visitor = connection.visitor + relation = self if eager_loading? find_with_associations { |rel| relation = rel } end - binds = relation.bound_attributes - binds = connection.prepare_binds_for_database(binds) - binds.map! { |value| connection.quote(value) } - collect = visitor.accept(relation.arel.ast, Arel::Collectors::Bind.new) - collect.substitute_binds(binds).join + conn = klass.connection + conn.unprepared_statement { + conn.to_sql(relation.arel, relation.bound_attributes) + } end end |