aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2013-01-26 03:18:21 -0800
committerRafael Mendonça França <rafaelmfranca@gmail.com>2013-01-26 03:18:21 -0800
commit647d18c92c77b96754c7e9e3d9142f18e0772061 (patch)
tree5655e91d3cf2953515cc2d3c212bbc861c66953d /activerecord/lib
parent9df25844ba77f5ebdfe6178c78c63de53c15c45c (diff)
parent648def406023b38310287588eb5efdfc739253e2 (diff)
downloadrails-647d18c92c77b96754c7e9e3d9142f18e0772061.tar.gz
rails-647d18c92c77b96754c7e9e3d9142f18e0772061.tar.bz2
rails-647d18c92c77b96754c7e9e3d9142f18e0772061.zip
Merge pull request #9078 from senny/6865_ar_count_with_uniq
`#count` in conjunction with `#uniq` performs distinct count.
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/relation/calculations.rb3
1 files changed, 2 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/relation/calculations.rb b/activerecord/lib/active_record/relation/calculations.rb
index 3f154bd1cc..f10c290755 100644
--- a/activerecord/lib/active_record/relation/calculations.rb
+++ b/activerecord/lib/active_record/relation/calculations.rb
@@ -192,7 +192,8 @@ module ActiveRecord
def perform_calculation(operation, column_name, options = {})
operation = operation.to_s.downcase
- distinct = options[:distinct]
+ # If #count is used in conjuction with #uniq it is considered distinct. (eg. relation.uniq.count)
+ distinct = options[:distinct] || self.uniq_value
if operation == "count"
column_name ||= (select_for_count || :all)