Reduce database queries when returning the User list resource.
Review Request #4825 — Created Oct. 21, 2013 and submitted — Latest diff uploaded
Reduce database queries when returning the User list resource.
The User API resource checked profile.is_private on each User being
serialized in a list, which is expensive. Unfortunately, neither
select_related() nor prefetch_related() appear to properly cache reverse
ForeignKey relations, so they don't help us with this.The best solution, it seems, is to tack on an extra query for our users,
storing the result of Profile.is_private on the User. The
is_profile_visible function checks for this, and attempts to do the
right thing by making use of that value, if it's available.
Viewed the query count and list of queries before and after this change.
Before the change, there was an extra query per listed user. After,
there was a flat amount of 4 (which includes session and auth queries).
Diff Revision 2 (Latest)
reviewboard/accounts/managers.py |
---|
reviewboard/accounts/middleware.py |
---|
reviewboard/accounts/models.py |
---|
reviewboard/accounts/tests.py |
---|
reviewboard/diffviewer/diffutils.py |
---|
reviewboard/reviews/datagrids.py |
---|
reviewboard/reviews/managers.py |
---|
reviewboard/reviews/tests.py |
---|
reviewboard/reviews/views.py |
---|
reviewboard/reviews/templatetags/reviewtags.py |
---|
reviewboard/webapi/resources/base_watched_object.py |
---|
reviewboard/webapi/resources/user.py |
---|
reviewboard/webapi/tests/test_watched_review_group.py |
---|
reviewboard/webapi/tests/test_watched_review_request.py |
---|