1
0
Fork 0
mirror of https://codeberg.org/demostf/api.git synced 2026-06-03 18:04:08 +02:00

optimize single player search

This commit is contained in:
Robin Appelman 2020-11-28 14:48:45 +01:00
commit 979a1722ae
3 changed files with 18 additions and 10 deletions

View file

@ -4,7 +4,7 @@ docker:
.PHONY: testdb .PHONY: testdb
testdb: testdb:
docker run -d --name api-test -p 5433:5432 -e POSTGRES_PASSWORD=test demostf/db docker run -d --name api-test-db -p 5433:5432 -e POSTGRES_PASSWORD=test demostf/db
node_modules: package.json node_modules: package.json
npm install npm install

View file

@ -7,7 +7,8 @@
"ehesp/steam-login": "^1.2", "ehesp/steam-login": "^1.2",
"koraktor/steam-condenser": "^1.3", "koraktor/steam-condenser": "^1.3",
"guzzlehttp/guzzle": "^6.3", "guzzlehttp/guzzle": "^6.3",
"doctrine/dbal": "^2.9" "doctrine/dbal": "^2.9",
"ext-pdo": "*"
}, },
"autoload": { "autoload": {
"files": [ "files": [

View file

@ -30,14 +30,21 @@ class DemoListProvider extends BaseProvider {
$query = $this->getQueryBuilder(); $query = $this->getQueryBuilder();
$query->select('p.demo_id') $query->select('p.demo_id')
->from('players', 'p') ->from('players', 'p')
->where($query->expr()->in('user_id', $query->createNamedParameter($userIds, Connection::PARAM_INT_ARRAY))) ->innerJoin('p', 'demos', 'd', $query->expr()->eq('demo_id', 'd.id'));
->innerJoin('p', 'demos', 'd', $query->expr()->eq('demo_id', 'd.id'))
if (count($userIds) > 1) {
$query->where($query->expr()->in('user_id',
$query->createNamedParameter($userIds, Connection::PARAM_INT_ARRAY)))
->groupBy('demo_id') ->groupBy('demo_id')
->having($query->expr()->eq( ->having($query->expr()->eq(
'COUNT(user_id)', 'COUNT(user_id)',
$query->createNamedParameter(count($userIds, PDO::PARAM_INT)) $query->createNamedParameter(count($userIds, PDO::PARAM_INT))
)) ));
->orderBy('demo_id', 'desc') } else {
$query->where($query->expr()->eq('user_id',
$query->createNamedParameter($userIds[0], PDO::PARAM_INT)));
}
$query->orderBy('demo_id', 'desc')
->setMaxResults(50) ->setMaxResults(50)
->setFirstResult(((int) $page - 1) * 50); ->setFirstResult(((int) $page - 1) * 50);