summary refs log tree commit diff
path: root/synapse/storage/search.py
diff options
context:
space:
mode:
authorAndrew Morgan <andrew@amorgan.xyz>2020-02-26 12:36:30 +0000
committerAndrew Morgan <andrew@amorgan.xyz>2020-02-26 12:36:30 +0000
commit0d542b03deaa9a3719aeb7d5e43d1a070deacabc (patch)
tree25b459fc33d47004bcc6da5bd40d017e4c686b6a /synapse/storage/search.py
parentMerge pull request #6186 from matrix-org/erikj/disable_sql_bytes (diff)
parentMerge pull request #6156 from matrix-org/erikj/postgres_any (diff)
downloadsynapse-0d542b03deaa9a3719aeb7d5e43d1a070deacabc.tar.xz
Merge pull request #6156 from matrix-org/erikj/postgres_any
Diffstat (limited to 'synapse/storage/search.py')
-rw-r--r--synapse/storage/search.py13
1 files changed, 9 insertions, 4 deletions
diff --git a/synapse/storage/search.py b/synapse/storage/search.py

index 6ba4190f1a..7695bf09fc 100644 --- a/synapse/storage/search.py +++ b/synapse/storage/search.py
@@ -24,6 +24,7 @@ from canonicaljson import json from twisted.internet import defer from synapse.api.errors import SynapseError +from synapse.storage._base import make_in_list_sql_clause from synapse.storage.engines import PostgresEngine, Sqlite3Engine from .background_updates import BackgroundUpdateStore @@ -385,8 +386,10 @@ class SearchStore(SearchBackgroundUpdateStore): # Make sure we don't explode because the person is in too many rooms. # We filter the results below regardless. if len(room_ids) < 500: - clauses.append("room_id IN (%s)" % (",".join(["?"] * len(room_ids)),)) - args.extend(room_ids) + clause, args = make_in_list_sql_clause( + self.database_engine, "room_id", room_ids + ) + clauses = [clause] local_clauses = [] for key in keys: @@ -492,8 +495,10 @@ class SearchStore(SearchBackgroundUpdateStore): # Make sure we don't explode because the person is in too many rooms. # We filter the results below regardless. if len(room_ids) < 500: - clauses.append("room_id IN (%s)" % (",".join(["?"] * len(room_ids)),)) - args.extend(room_ids) + clause, args = make_in_list_sql_clause( + self.database_engine, "room_id", room_ids + ) + clauses = [clause] local_clauses = [] for key in keys: