【问题标题】:Sorting joined table with KnpPaginatorBundle使用 KnpPaginatorBundle 对连接表进行排序
【发布时间】:2013-03-05 08:20:12
【问题描述】:

我设置了一个测试来更熟悉 Symfony2 和 KnpPaginatorBundle。我有一张宠物表,其中引用了宠物动物类型(DogCat 等)。我可以按idname 排序,但是当我尝试按动物type 排序时,我收到一条错误消息:

在给定的 Query 组件中没有这样的字段 [animalkind],别名为 [a]

我尝试了各种字段名称,但似乎没有任何效果。

实体:MyPets.php

<?php
namespace Xyz\TestBundle\Entity;
use Doctrine\ORM\Mapping as ORM;

/**
 * MyPet
 */

class MyPet
{
    /**
     * @var integer
     */
    private $id;

    /**
     * @var string
     */
    private $name;

    /**
     * Set id
     *
     * @param integer $id
     * @return MyPet
     */
    public function setId($id)
    {
        $this->id = $id;
        return $this;
    }

    /**
     * Get id
     *
     * @return integer 
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Set name
     *
     * @param string $name
     * @return MyPet
     */
    public function setName($name)
    {
        $this->name = $name;
        return $this;
    }

    /**
     * Get name
     *
     * @return string 
     */
    public function getName()
    {
        return $this->name;
    }
    /**
     * @var \Xyz\TestBundle\Entity\AnimalKind
     */
    private $AnimalKind;

    /**
     * Set AnimalKind
     *
     * @param \Xyz\TestBundle\Entity\AnimalKind $animalKind
     * @return MyPet
     */
    public function setAnimalKind(\Xyz\TestBundle\Entity\AnimalKind $animalKind)
    {
        $this->AnimalKind = $animalKind;
        return $this;
    }

    /**
     * Get AnimalKind
     *
     * @return \Xyz\TestBundle\Entity\AnimalKind 
     */
    public function getAnimalKind()
    {
        return $this->AnimalKind;

    }
}

实体:AnimalKind.php

<?php
namespace Xyz\TestBundle\Entity;
use Doctrine\ORM\Mapping as ORM;

/**
 * AnimalKind
 */
class AnimalKind {

    /**
     * @var integer
     */
    private $id;

    /**
     * @var string
     */
    private $type;

    /**
     * Get id
     *
     * @return integer 
     */
    public function getId() {
        return $this->id;
    }

    /**
     * Set type
     *
     * @param string $type
     * @return AnimalKind
     */
    public function setType($type) {
        $this->type = $type;

        return $this;
    }

    /**
     * Get type
     *
     * @return string 
     */
    public function getType() {
        return $this->type;
    }

    /**
     * @var \Doctrine\Common\Collections\Collection
     */
    private $MyPets;

    /**
     * Constructor
     */
    public function __construct() {
        $this->MyPets = new \Doctrine\Common\Collections\ArrayCollection();
    }

    /**
     * Add MyPets
     *
     * @param \Xyz\TestBundle\Entity\MyPet $myPets
     * @return AnimalKind
     */
    public function addMyPet(\Xyz\TestBundle\Entity\MyPet $myPets) {
        $this->MyPets[] = $myPets;

        return $this;
    }

    /**
     * Remove MyPets
     *
     * @param \Xyz\TestBundle\Entity\MyPet $myPets
     */
    public function removeMyPet(\Xyz\TestBundle\Entity\MyPet $myPets) {
        $this->MyPets->removeElement($myPets);
    }

    /**
     * Get MyPets
     *
     * @return \Doctrine\Common\Collections\Collection 
     */
    public function getMyPets() {
        return $this->MyPets;
    }

    public function __toString() {
        return $this->getType();
    }

}

控制器:MyPetController.php (IndexAction)

    public function indexAction()
    {
        $em = $this->getDoctrine()->getManager();

        $query = $em->createQuery("SELECT a FROM XyzTestBundle:MyPet a");

        $paginator  = $this->get('knp_paginator');

        $pagination = $paginator->paginate($query,$this->get('request')->query->get('page', 
          1)/*page number*/,15/*limit per page*/);

        return $this->render('XyzTestBundle:MyPet:index.html.twig', array(
         'pagination' => $pagination,

        ));
    }

查看:MyPet/index.html.twig(截图)

<table class="records_list">
    <thead>
        <tr>
            {# sorting of properties based on query components #}
            <th>{{ knp_pagination_sortable(pagination, 'Id', 'a.id') }}</th>
            <th>{{ knp_pagination_sortable(pagination, 'Name', 'a.name') }}</th>
            <th>{{ knp_pagination_sortable(pagination, 'kind', 'a.animalkind') }}</th>
        </tr>
    </thead>
    <tbody>
    {% for mypet in pagination %}
        <tr>
            <td><a href="{{ path('xyz_mypet_show', { 'id': mypet.id }) }}">{{ mypet.id }}</a></td>
            <td>{{ mypet.name }}</td>
            <td>{{ mypet.animalkind }}</td>
        </tr>
    {% endfor %}
    </tbody>
</table>

谁能告诉我关于这个问题的任何见解?

【问题讨论】:

    标签: sorting symfony doctrine-orm pagination


    【解决方案1】:

    第一个问题是缺少ORM关系声明;基本上在您的数据库中 YourPet 不能关联到 AnimalKind

    您可以找到有关 Entity relationships and associations on the Symfony's website 的文档。

    YourPet 实体的角度来看,您可能希望使用多对一关系。

    解决上述问题后,第二个问题是您没有在查询中加入 AnimalKind 实体。

    第三个问题是不能按实体对查询结果进行排序。

    第一个问题的潜在解决方案:

    // In MyPet class
    /**
     * @var \Xyz\TestBundle\Entity\AnimalKind
     * @ORM\OneToMany(targetEntity="AnimalKind", inversedBy="MyPets")
     */
    private $AnimalKind;
    
    // In AnimalKind class
    /**
     * @var \Doctrine\Common\Collections\Collection
     * @ORM\ManyToOne(targetEntity="MyPet", inversedBy="AnimalKind")
     */
    private $MyPets;
    

    第二个问题的潜在解决方案:

    $query = $em->createQuery("
        SELECT a, k
        FROM XyzTestBundle:MyPet a
        JOIN a.animalKind k 
    ");
    

    第三个问题的潜在解决方案:

    <th>{{ knp_pagination_sortable(pagination, 'kind', 'k.type') }}</th>
    

    【讨论】:

    • 感谢埃尔努尔!我没有更改实体,但我按照您的建议添加了 JOIN 和 k.type 代码并且它有效。经过考虑,我真的需要按 animalkind.type 排序。
    【解决方案2】:

    要显示没有 animalKind 的动物,您必须在查询中使用 LEFT JOIN

    $query = $em->createQuery("
        SELECT a, k
        FROM XyzTestBundle:MyPet a
        LEFT JOIN a.animalKind k 
    ");
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-07-21
      • 2023-03-19
      • 2021-02-11
      • 2015-04-27
      • 2010-11-18
      • 1970-01-01
      • 1970-01-01
      • 2017-11-09
      相关资源
      最近更新 更多