perform_calculation(operation, column_name, options = {}) private

No documentation

This method has no description. You can help the Ruby on Rails community by adding new notes.

Hide source
# File activerecord/lib/active_record/relation/calculations.rb, line 198
    def perform_calculation(operation, column_name, options = {})
      operation = operation.to_s.downcase

      # If #count is used with #distinct / #uniq it is considered distinct. (eg. relation.distinct.count)
      distinct = self.distinct_value
      if options.has_key?(:distinct)
        ActiveSupport::Deprecation.warn "The :distinct option for `Relation#count` is deprecated. "            "Please use `Relation#distinct` instead. (eg. `relation.distinct.count`)"
        distinct = options[:distinct]
      end

      if operation == "count"
        column_name ||= (select_for_count || :all)

        unless arel.ast.grep(Arel::Nodes::OuterJoin).empty?
          distinct = true
        end

        column_name = primary_key if column_name == :all && distinct

        distinct = nil if column_name =~ /\s*DISTINCT\s+/
      end

      if group_values.any?
        execute_grouped_calculation(operation, column_name, distinct)
      else
        execute_simple_calculation(operation, column_name, distinct)
      end
    end
Register or log in to add new notes.