connection->createQueryBuilder(); $result = $qb->select('id') ->from('short_urls') ->executeQuery(); while ($shortUrlId = $result->fetchOne()) { $visitsQb = $this->connection->createQueryBuilder(); $visitsQb->select('COUNT(id)') ->from('visits') ->where($visitsQb->expr()->eq('short_url_id', ':short_url_id')) ->andWhere($visitsQb->expr()->eq('potential_bot', ':potential_bot')) ->setParameter('short_url_id', $shortUrlId); $botsCount = $visitsQb->setParameter('potential_bot', '1')->executeQuery()->fetchOne(); $nonBotsCount = $visitsQb->setParameter('potential_bot', '0')->executeQuery()->fetchOne(); if ($botsCount > 0) { $this->insertCount($shortUrlId, $botsCount, potentialBot: true); } if ($nonBotsCount > 0) { $this->insertCount($shortUrlId, $nonBotsCount, potentialBot: false); } } } private function insertCount(string $shortUrlId, int $count, bool $potentialBot): void { $this->connection->createQueryBuilder() ->insert('short_url_visits_counts') ->values([ 'short_url_id' => ':short_url_id', 'count' => ':count', 'potential_bot' => ':potential_bot', ]) ->setParameters([ 'short_url_id' => $shortUrlId, 'count' => $count, 'potential_bot' => $potentialBot ? '1' : '0', ]) ->executeStatement(); } }