diff options
-rw-r--r-- | activerecord/CHANGELOG | 2 | ||||
-rwxr-xr-x | activerecord/lib/active_record/base.rb | 20 |
2 files changed, 16 insertions, 6 deletions
diff --git a/activerecord/CHANGELOG b/activerecord/CHANGELOG index 5cd21b65f6..d05261ae94 100644 --- a/activerecord/CHANGELOG +++ b/activerecord/CHANGELOG @@ -1,6 +1,6 @@ *SVN* -* Enhance documentation for decrement_counter. [fearoffish] +* Enhance documentation for increment_counter and decrement_counter. [fearoffish] * Provide brief introduction to what optimistic locking is. [fearoffish] diff --git a/activerecord/lib/active_record/base.rb b/activerecord/lib/active_record/base.rb index 43879603e3..87bd064e49 100755 --- a/activerecord/lib/active_record/base.rb +++ b/activerecord/lib/active_record/base.rb @@ -555,11 +555,21 @@ module ActiveRecord #:nodoc: update_all(updates, "#{connection.quote_column_name(primary_key)} = #{quote_value(id)}") end - # Increments the specified counter by one. So <tt>DiscussionBoard.increment_counter("post_count", - # discussion_board_id)</tt> would increment the "post_count" counter on the board responding to discussion_board_id. - # This is used for caching aggregate values, so that they don't need to be computed every time. Especially important - # for looping over a collection where each element require a number of aggregate values. Like the DiscussionBoard - # that needs to list both the number of posts and comments. + # Increment a number field by one, usually representing a count. + # + # This is used for caching aggregate values, so that they don't need to be computed every time. + # For example, a DiscussionBoard may cache post_count and comment_count otherwise every time the board is + # shown it would have to run a SQL query to find how many posts and comments there are. + # + # ==== Options + # + # +counter_name+ The name of the field that should be incremented + # +id+ The id of the object that should be incremented + # + # ==== Examples + # + # # Increment the post_count column for the record with an id of 5 + # DiscussionBoard.increment_counter(:post_count, 5) def increment_counter(counter_name, id) update_counters(id, counter_name => 1) end |