Commit ac423bb
committed
fix: eager load permissions and organisers in DashboardController
Motivation:
Bullet was reporting N+1 queries on the homepage (/). The view accesses
event.organisers which requires the permissions join table to be eager loaded.
Analysis:
- The all_events method loads Event and Workshop objects that need
organisers and permissions preloaded
- Also fixed Meeting eager loading to include permissions
- Changed from includes() to eager_load() to handle nested through-associations
(organisers goes through permissions)
Before: N+1 queries per event for organisers
After: Single query with JOIN on permissions table.1 parent 0f6cc31 commit ac423bb
1 file changed
Lines changed: 10 additions & 8 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
57 | 57 | | |
58 | 58 | | |
59 | 59 | | |
60 | | - | |
| 60 | + | |
| 61 | + | |
61 | 62 | | |
| 63 | + | |
62 | 64 | | |
63 | 65 | | |
64 | 66 | | |
| |||
77 | 79 | | |
78 | 80 | | |
79 | 81 | | |
80 | | - | |
81 | | - | |
| 82 | + | |
| 83 | + | |
82 | 84 | | |
83 | 85 | | |
84 | 86 | | |
85 | | - | |
| 87 | + | |
86 | 88 | | |
87 | | - | |
88 | 89 | | |
89 | 90 | | |
90 | 91 | | |
91 | 92 | | |
92 | 93 | | |
93 | | - | |
| 94 | + | |
94 | 95 | | |
95 | 96 | | |
96 | 97 | | |
| |||
99 | 100 | | |
100 | 101 | | |
101 | 102 | | |
102 | | - | |
103 | | - | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
104 | 106 | | |
105 | 107 | | |
106 | 108 | | |
| |||
0 commit comments