aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/relation.rb
diff options
context:
space:
mode:
authorRyuta Kamizono <kamipo@gmail.com>2016-07-19 19:52:00 +0900
committerRyuta Kamizono <kamipo@gmail.com>2016-07-19 20:06:58 +0900
commit3befc7a9ef4740fc4af5cc256e4c4589e0aea562 (patch)
treecac5518808fcd4db12934c11db7e3ffd11aac8f8 /activerecord/lib/active_record/relation.rb
parentd8bc0964d29837407efe425d7a65ab9a27d96e82 (diff)
downloadrails-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/relation.rb')
-rw-r--r--activerecord/lib/active_record/relation.rb15
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