回答編集履歴
2
画像を見て、また違う気がしたので修正します。度々すみません
test
CHANGED
@@ -1,9 +1,27 @@
|
|
1
|
-
|
1
|
+
`.count`を取るような場合、Active Recordだけでは効率的にハンドリングしてくれないので、別途で`GROUP BY`をかけて取得するほうがいい、ということになるケースもあります。
|
2
2
|
|
3
3
|
|
4
4
|
|
5
|
+
```ruby
|
6
|
+
|
5
|
-
|
7
|
+
## コントローラー側
|
6
8
|
|
7
9
|
|
8
10
|
|
11
|
+
@cheers_count = Cheer.group(:post_id).count
|
12
|
+
|
9
|
-
|
13
|
+
@sympathies_count = Sympathy.group(:post_id).count
|
14
|
+
|
15
|
+
|
16
|
+
|
17
|
+
## ビュー側
|
18
|
+
|
19
|
+
- posts.each do |post|
|
20
|
+
|
21
|
+
@cheers_count[post.id]
|
22
|
+
|
23
|
+
@sympathies_count[post.id]
|
24
|
+
|
25
|
+
|
26
|
+
|
27
|
+
```
|
1
includesでも遅かったとのことなので、回答を修正します
test
CHANGED
@@ -1,9 +1,9 @@
|
|
1
|
-
|
1
|
+
(includesでも遅かった&bulletも使用中とのことなので、回答を修正します)
|
2
2
|
|
3
3
|
|
4
4
|
|
5
|
-
|
5
|
+
全件取得のようにデータが多い場合、DB上で`JOIN`してくれる`.eager_load`を使うほうが、1度引きで済むのでいいかもしれません。
|
6
6
|
|
7
7
|
|
8
8
|
|
9
|
-
|
9
|
+
[ActiveRecordのjoinsとpreloadとincludesとeager_loadの違い](http://qiita.com/k0kubun/items/80c5a5494f53bb88dc58)
|