0

私はknp paginatorでページネーションをしようとしています。

私は同じウェブサイトの他の場所でそれを使用していますが、彼は正常に動作します。

しかし、今は他のクエリで使用しようとしていますが、問題があります。

    $query = $src->getQuery();
    //die(print_r($query->getDQL()));
    //die(print_r($query->getParameters()));
    $paginator = $this->get('knp_paginator');
    $paginator = $paginator->paginate(
        $query,
        $this->get('request')->query->get('page', 1),
        15
    );

$src は、クエリを作成するためのカスタム サービスです。die 行 "getDQL" は、次の DQL を返します。

SELECT p FROM YOUProductBundle:Product p INNER JOIN p.boutique b INNER JOIN p.material m INNER JOIN p.cat1 cat WHERE p.stock > 0 AND p.type = :type AND cat.id = :cat AND b.latitude >= :latN AND b.latitude <= :latP AND b.longitude >= :lonN AND b.longitude <= :lonP AND distance(b.latitude,b.longitude,48.583148,7.747882000000004) <= :rayon ORDER BY m.prix ASC

die 行 "getParameters" は、次のデータを返します。

Doctrine\Common\Collections\ArrayCollection Object
(
[_elements:Doctrine\Common\Collections\ArrayCollection:private] => Array
    (
        [0] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => type
                [value:Doctrine\ORM\Query\Parameter:private] => material
                [type:Doctrine\ORM\Query\Parameter:private] => 2
            )

        [1] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => cat
                [value:Doctrine\ORM\Query\Parameter:private] => 21
                [type:Doctrine\ORM\Query\Parameter:private] => integer
            )

        [2] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => latP
                [value:Doctrine\ORM\Query\Parameter:private] => 49.257639204439
                [type:Doctrine\ORM\Query\Parameter:private] => 2
            )

        [3] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => latN
                [value:Doctrine\ORM\Query\Parameter:private] => 47.908656795561
                [type:Doctrine\ORM\Query\Parameter:private] => 2
            )

        [4] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => lonP
                [value:Doctrine\ORM\Query\Parameter:private] => 8.7674709750602
                [type:Doctrine\ORM\Query\Parameter:private] => 2
            )

        [5] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => lonN
                [value:Doctrine\ORM\Query\Parameter:private] => 6.7282930249398
                [type:Doctrine\ORM\Query\Parameter:private] => 2
            )

        [6] => Doctrine\ORM\Query\Parameter Object
            (
                [name:Doctrine\ORM\Query\Parameter:private] => rayon
                [value:Doctrine\ORM\Query\Parameter:private] => 75
                [type:Doctrine\ORM\Query\Parameter:private] => 2
            )

    )

)

エラーはありませんが、このクエリの結果は 0 です。今、「$query->getArrayResult()」を実行しようとすると、5 つの結果が得られます。

ページネーターが 5 つの通常の結果を得られないのはなぜですか?

4

1 に答える 1

0

パラメーターの順序が正しくありません...パラメーターを設定するときに、正しい順序で設定していません。次を参照してください。

            ->andWhere('b.latitude >= :latN')
            ->andWhere('b.latitude <= :latP')
            ->andWhere('b.longitude >= :lonN')
            ->andWhere('b.longitude <= :lonP')
            ->andWhere('distance(b.latitude,b.longitude,'.$datas['lat'].','.$datas['lon'].') <= :rayon')
            ->setParameter('latP',$latP)
            ->setParameter('latN',$latN)
            ->setParameter('lonP',$lonP)
            ->setParameter('lonN',$lonN)
            ->setParameter('rayon',$datas['search']);

「latP」を「latN」に、「lonP」を「lonN」に反転させます。

クエリビルダーを使用する場合は問題ありません...しかし、ページネーター用にクエリをエクスポートすると、最終的なクエリとパラメーター配列が適切な順序でなく、正しいクエリを実行できません....

于 2013-10-28T07:44:49.833 に答える