TL;DR: You should generally use #size to count associated records.
size
- Counts already loaded elements
- If the association is not loaded, falls back to a COUNTquery
count
- If a counter cache is set up, returns the cached value
- Issues a COUNTquery else
Caveats
- If you trigger a COUNTquery for an association of an an unsaved record, Rails will try to load all children where the foreign keyIS NULL. This is not what you want. To prevent this behavior, you can useunsaved_record.association.to_a.size.
- 
countlooks directly into the database, neglecting already loaded elements. This becomes a problem when you use that "db count" and process the loaded elements.
 A common example is tests: Imagine a test that sets up a few records and finishes the test setup by asserting a number of associated records. If you use.countfor that job, the assertion cannot see that the setup records have loaded (i.e. cached) their associations too early and now are missing elements. Tests relying on the setup will fail, because they will operate on the loaded records. You will hardly notice, because you rely on the assertion. Using.sizeavoids this problem.
length
- Loads all records from the database, then returns the number of elements
Posted by Dominik Schöler to makandra dev (2013-03-13 09:38)