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:
parent
dddf5933d2
commit
979a1722ae
3 changed files with 18 additions and 10 deletions
2
Makefile
2
Makefile
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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": [
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue