<?php
namespace App\Repository\Symboles;
use App\Entity\Symboles\Symbolesetats;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\Persistence\ManagerRegistry;
/**
* @method Symbolesetats|null find($id, $lockMode = null, $lockVersion = null)
* @method Symbolesetats|null findOneBy(array $criteria, array $orderBy = null)
* @method Symbolesetats[] findAll()
* @method Symbolesetats[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
*/
class SymbolesetatsRepository extends ServiceEntityRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, Symbolesetats::class);
}
public function latest(int $limit)
{
return $this->createQueryBuilder('s')
->andWhere('s.online = 1')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
public function getSymbolesRandom(Symbolesetats $symbolesetat, $limit)
{
return $this->createQueryBuilder('s')
->andWhere('s.id != :symbolesetat')
->setParameter('symbolesetat', $symbolesetat)
->orderBy('RAND()')
->setMaxResults($limit)
->getQuery()
->getResult()
;
}
public function findSingleSymbole(int $id): ?Symbolesetats
{
return $this->createQueryBuilder('s')
->andWhere('s.id = :id')
->andWhere('s.online = 1')
->setParameter('id', $id)
->getQuery()
->getOneOrNullResult()
;
}
}