diff options
| author | Sean Griffin <sean@seantheprogrammer.com> | 2016-07-26 17:38:17 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-07-26 17:38:17 -0400 | 
| commit | d980abdb23f70409dfec90306cbf5ce9d9df17d7 (patch) | |
| tree | e580d9408366eea7a4ce7ad25ec2272f19d9bdfe /activerecord/lib | |
| parent | 6594226c9ceec68fe2320e876f029f66cfd8c20e (diff) | |
| parent | d31c2e2cf886c7b8fe4a05ab99c3e629991ffd79 (diff) | |
| download | rails-d980abdb23f70409dfec90306cbf5ce9d9df17d7.tar.gz rails-d980abdb23f70409dfec90306cbf5ce9d9df17d7.tar.bz2 rails-d980abdb23f70409dfec90306cbf5ce9d9df17d7.zip | |
Merge pull request #25523 from kamipo/extract_quoted_binds_type_casted_binds
Extract `type_casted_binds` method
Diffstat (limited to 'activerecord/lib')
4 files changed, 10 insertions, 6 deletions
| diff --git a/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb b/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb index 860ef17dca..9af6a673d3 100644 --- a/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb +++ b/activerecord/lib/active_record/connection_adapters/abstract/quoting.rb @@ -156,6 +156,10 @@ module ActiveRecord        private +      def type_casted_binds(binds) +        binds.map { |attr| type_cast(attr.value_for_database) } +      end +        def types_which_need_no_typecasting          [nil, Numeric, String]        end diff --git a/activerecord/lib/active_record/connection_adapters/mysql/database_statements.rb b/activerecord/lib/active_record/connection_adapters/mysql/database_statements.rb index cc19d95669..6d1215df2a 100644 --- a/activerecord/lib/active_record/connection_adapters/mysql/database_statements.rb +++ b/activerecord/lib/active_record/connection_adapters/mysql/database_statements.rb @@ -77,7 +77,7 @@ module ActiveRecord              @connection.query_options[:database_timezone] = ActiveRecord::Base.default_timezone            end -          type_casted_binds = binds.map { |attr| type_cast(attr.value_for_database) } +          type_casted_binds = type_casted_binds(binds)            log(sql, name, binds, type_casted_binds) do              if cache_stmt diff --git a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb index 487165d511..61a980fda9 100644 --- a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb @@ -597,13 +597,13 @@ module ActiveRecord          end          def exec_no_cache(sql, name, binds) -          type_casted_binds = binds.map { |attr| type_cast(attr.value_for_database) } +          type_casted_binds = type_casted_binds(binds)            log(sql, name, binds, type_casted_binds) { @connection.async_exec(sql, type_casted_binds) }          end          def exec_cache(sql, name, binds)            stmt_key = prepare_statement(sql) -          type_casted_binds = binds.map { |attr| type_cast(attr.value_for_database) } +          type_casted_binds = type_casted_binds(binds)            log(sql, name, binds, type_casted_binds, stmt_key) do              @connection.exec_prepared(stmt_key, type_casted_binds) diff --git a/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb b/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb index ed6bff4665..41ed784d2e 100644 --- a/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb +++ b/activerecord/lib/active_record/connection_adapters/sqlite3_adapter.rb @@ -188,7 +188,7 @@ module ActiveRecord        end        def exec_query(sql, name = nil, binds = [], prepare: false) -        type_casted_binds = binds.map { |attr| type_cast(attr.value_for_database) } +        type_casted_binds = type_casted_binds(binds)          log(sql, name, binds, type_casted_binds) do            # Don't cache statements if they are not prepared @@ -203,7 +203,6 @@ module ActiveRecord              ensure                stmt.close              end -            stmt = records            else              cache = @statements[sql] ||= {                :stmt => @connection.prepare(sql) @@ -212,9 +211,10 @@ module ActiveRecord              cols = cache[:cols] ||= stmt.columns              stmt.reset!              stmt.bind_params(type_casted_binds) +            records = stmt.to_a            end -          ActiveRecord::Result.new(cols, stmt.to_a) +          ActiveRecord::Result.new(cols, records)          end        end | 
