diff options
author | Erik Johnston <erik@matrix.org> | 2019-07-24 11:49:15 +0100 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2019-07-24 11:49:15 +0100 |
commit | 0c4a99607e839c5a363351238a6a555015c8ddfc (patch) | |
tree | 18de26984164798bdc43f12443d7f4783c375c98 /synapse/storage | |
parent | Remove join on room_memberships when fetching rooms for user. (diff) | |
download | synapse-0c4a99607e839c5a363351238a6a555015c8ddfc.tar.xz |
Remove join when calculating room summaries.
Diffstat (limited to 'synapse/storage')
-rw-r--r-- | synapse/storage/roommember.py | 34 |
1 files changed, 21 insertions, 13 deletions
diff --git a/synapse/storage/roommember.py b/synapse/storage/roommember.py index 7852d3866a..bfb834ccca 100644 --- a/synapse/storage/roommember.py +++ b/synapse/storage/roommember.py @@ -179,19 +179,27 @@ class RoomMemberWorkerStore(EventsWorkerStore): # we order by membership and then fairly arbitrarily by event_id so # heroes are consistent - sql = """ - SELECT m.user_id, m.membership, m.event_id - FROM room_memberships as m - INNER JOIN current_state_events as c - ON m.event_id = c.event_id - AND m.room_id = c.room_id - AND m.user_id = c.state_key - WHERE c.type = 'm.room.member' AND c.room_id = ? - ORDER BY - CASE m.membership WHEN ? THEN 1 WHEN ? THEN 2 ELSE 3 END ASC, - m.event_id ASC - LIMIT ? - """ + if self._current_state_events_membership_up_to_date: + sql = """ + SELECT state_key, membership, event_id + FROM current_state_events + WHERE type = 'm.room.member' AND room_id = ? + ORDER BY + CASE membership WHEN ? THEN 1 WHEN ? THEN 2 ELSE 3 END ASC, + event_id ASC + LIMIT ? + """ + else: + sql = """ + SELECT c.state_key, m.membership, c.event_id + FROM room_memberships as m + INNER JOIN current_state_events as c USING (room_id, event_id) + WHERE c.type = 'm.room.member' AND c.room_id = ? + ORDER BY + CASE m.membership WHEN ? THEN 1 WHEN ? THEN 2 ELSE 3 END ASC, + c.event_id ASC + LIMIT ? + """ # 6 is 5 (number of heroes) plus 1, in case one of them is the calling user. txn.execute(sql, (room_id, Membership.JOIN, Membership.INVITE, 6)) |