J'essaie de faire la pagination, mais il y a une erreur:
[Erreur de syntaxe] ligne 0, col 57: Erreur: fin de chaîne attendue, avec 'limite'
Je ne suis pas tout à fait sûr que ce soit la bonne syntaxe (et logique) pour faire ma requête:
public function getFriendsFromTo ($user, $limit, $offset)
{
return $this->getEntityManager()
->createQuery('SELECT f FROM EMMyFriendsBundle:Friend f WHERE f.user='.$user.' limit '.$limit. 'offset' .$offset)
->getResult();
}
Les amis et les utilisateurs sont liés à manyToOne et à oneToMany. Il existe donc un champ dans la table des amis - user_id.
Ceci est dans mon contrôleur:
$user = $this->get('security.context')->getToken()->getUser();
$id = $user->getId();
$friends = $user->getFriends();
$result = count($friends)
$FR_PER_PAGE = 7;
$pages = $result/$FR_PER_PAGE;
$em = $this->getDoctrine()->getEntityManager();
$friends = $em->getRepository('EMMyFriendsBundle:Friend')
->getFriendsFromTo($id, $FR_PER_PAGE, $page*$FR_PER_PAGE);
Je sais que c'est stupide et même faux (surtout le troisième paramètre à être $page*$FR_PER_PAGE
), mais je voulais juste essayer si la requête fonctionnait, mais cela n’a pas fonctionné.
Nan. Utilisation:
return $this->getEntityManager()
->createQuery('...')
->setMaxResults(5)
->setFirstResult(10)
->getResult();
$towary = $this->getDoctrine()
->getRepository('AcmeStoreBundle:Towar')
->findBy(array(),array(),10,($current-1)*$numItemsPerPage);
Vous pouvez utiliser findBy
les 3ème et 4ème paramètres de la méthode de doctrine du référentiel, qui sont limit
et offset
.
Voici la définition de la méthode:
findBy(
array $criteria,
array $orderBy = null,
integer|null $limit = null,
integer|null $offset = null
)
Source: http://www.doctrine-project.org/api/orm/2.2/class-Doctrine.ORM.EntityRepository.html
vous pouvez aussi utiliser
$ query-> getSingleResult ();