Sha256: 41b3a6d79168d32930fb0360edff8db9075cc34a8d9fdd1868191a6645e32a2f
Contents?: true
Size: 1.74 KB
Versions: 1
Compression:
Stored size: 1.74 KB
Contents
# frozen_string_literal: true require "active_record/relation" require "active_record/version" module ActiveRecord module ConnectionAdapters module SQLServer module CoreExt module Calculations # Same as original except we don't perform PostgreSQL hack that removes ordering. def calculate(operation, column_name) return super unless klass.connection.adapter_name == "SQLServer" if has_include?(column_name) relation = apply_join_dependency if operation.to_s.downcase == "count" unless distinct_value || distinct_select?(column_name || select_for_count) relation.distinct! relation.select_values = [klass.primary_key || table[Arel.star]] end end relation.calculate(operation, column_name) else perform_calculation(operation, column_name) end end private def build_count_subquery(relation, column_name, distinct) return super unless klass.connection.adapter_name == "SQLServer" super(relation.unscope(:order), column_name, distinct) end def type_cast_calculated_value(value, type, operation = nil) case operation when "count" then value.to_i when "sum" then type.deserialize(value || 0) when "average" then value&.respond_to?(:to_d) ? value.to_d : value else type.deserialize(value) end end end end end end end ActiveSupport.on_load(:active_record) do mod = ActiveRecord::ConnectionAdapters::SQLServer::CoreExt::Calculations ActiveRecord::Relation.prepend(mod) end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
activerecord-sqlserver-adapter-6.0.3 | lib/active_record/connection_adapters/sqlserver/core_ext/calculations.rb |