mirror of
https://codeberg.org/demostf/api.git
synced 2026-06-03 18:04:08 +02:00
move profile listing to query builder
This commit is contained in:
parent
be6b689336
commit
79d9f779f5
1 changed files with 13 additions and 7 deletions
|
|
@ -22,15 +22,21 @@ class DemoListProvider extends BaseProvider {
|
||||||
foreach ($users as $user) {
|
foreach ($users as $user) {
|
||||||
$userIds[] = $user['id'];
|
$userIds[] = $user['id'];
|
||||||
}
|
}
|
||||||
$in = implode(', ', array_fill(0, count($userIds), '?'));
|
|
||||||
|
|
||||||
$sql = 'SELECT players.demo_id FROM players WHERE players.user_id IN (' . $in . ')
|
$query = $this->getQueryBuilder();
|
||||||
GROUP BY players.demo_id HAVING COUNT(user_id) = ? ORDER BY players.demo_id DESC LIMIT 50 OFFSET ' . ((int) $page - 1) * 50;
|
$query->select('p.demo_id')
|
||||||
|
->from('players', 'p')
|
||||||
|
->where($query->expr()->in('user_id', $query->createNamedParameter($userIds, Connection::PARAM_INT_ARRAY)))
|
||||||
|
->groupBy('demo_id')
|
||||||
|
->having($query->expr()->eq(
|
||||||
|
'COUNT(user_id)',
|
||||||
|
$query->createNamedParameter(count($userIds, \PDO::PARAM_INT))
|
||||||
|
))
|
||||||
|
->orderBy('demo_id')
|
||||||
|
->setMaxResults(50)
|
||||||
|
->setFirstResult(((int) $page - 1) * 50);
|
||||||
|
|
||||||
$params = $userIds;
|
$result = $query->execute();
|
||||||
$params[] = count($userIds);
|
|
||||||
|
|
||||||
$result = $this->query($sql, $params);
|
|
||||||
$demoIds = $result->fetchAll(\PDO::FETCH_COLUMN);
|
$demoIds = $result->fetchAll(\PDO::FETCH_COLUMN);
|
||||||
|
|
||||||
$demos = $this->db->demo()->where('id', $demoIds)
|
$demos = $this->db->demo()->where('id', $demoIds)
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue