mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2024-12-25 06:59:22 -05:00
Use windowing function to make use of index
This commit is contained in:
parent
94a83b534f
commit
d25c20ccbe
@ -322,11 +322,11 @@ class StateStore(SQLBaseStore):
|
|||||||
SELECT prev_state_group FROM state_group_edges e, state s
|
SELECT prev_state_group FROM state_group_edges e, state s
|
||||||
WHERE s.state_group = e.state_group
|
WHERE s.state_group = e.state_group
|
||||||
)
|
)
|
||||||
SELECT type, state_key, event_id FROM state_groups_state
|
SELECT type, state_key, last_value(event_id) OVER (
|
||||||
WHERE ROW(type, state_key, state_group) IN (
|
PARTITION BY type, state_key ORDER BY state_group ASC
|
||||||
SELECT type, state_key, max(state_group) FROM state
|
) AS event_id FROM state_groups_state
|
||||||
INNER JOIN state_groups_state USING (state_group)
|
WHERE state_group IN (
|
||||||
GROUP BY type, state_key
|
SELECT state_group FROM state
|
||||||
)
|
)
|
||||||
%s;
|
%s;
|
||||||
""") % (where_clause,)
|
""") % (where_clause,)
|
||||||
|
Loading…
Reference in New Issue
Block a user