【问题标题】:Symfony 4 - Problem with DQL for ordered arraySymfony 4 - 有序数组的 DQL 问题
【发布时间】:2019-08-23 21:10:01
【问题描述】:

我有一个“Validateur”实体,例如:

Validateur :
-id
-Validateur (User relation )
-Ordre (could be 0,1,2 ... )

和 GroupeValidateurs 实体如:

GroupeValidateurs:
-id
-validateurs (ManyToMany relation with Validateur entity)
-nom

我想为 myValidators 组进行诸如 findAll () 之类的查询,但这将返回包含按“Order”属性按升序排序的验证器数组的响应,例如:

- id : 1
- nom : "name Groupe"
- validateurs : array [
                      array[

                      id: 1
                      validateur: 1
                      ordre: 1
                      ],
                      array[

                      id: 2
                      validateur: 4
                      ordre: 2
                      ]
                      array[

                      id: 3
                      validateur: 6
                      ordre: 3
                      ]
]

我试过这个:

public function getValidateursGroupeParOrdre($groupe)
{
    return $this->createQueryBuilder('g')
        ->join('v.validateur', 'g')
        ->select('g.validateurs, g.nom')
        ->where('g.id = :groupe')
        ->orderBy('v.ordre', 'ASC')
        ->setParameter('groupe', $groupe)
        ->getQuery()
        ->getResult();
}

但不起作用。 这是我的实体:

GroupeValidateurs:

<?php

namespace App\Entity;

use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity(repositoryClass="App\Repository\GroupeValidateursRepository")
 */
class GroupeValidateurs
{
    /**
     * @ORM\Id()
     * @ORM\GeneratedValue()
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @ORM\ManyToMany(targetEntity="App\Entity\Validateur", inversedBy="groupeValidateurs", cascade={"persist"})
     */
    private $validateurs;

    /**
     * @ORM\Column(type="string", length=255)
     */
    private $nom;

    public function __construct()
    {
        $this->validateurs = new ArrayCollection();
    }

    public function getId(): ?int
    {
        return $this->id;
    }

    /**
     * @return Collection|Validateur[]
     */
    public function getValidateurs(): Collection
    {
        return $this->validateurs;
    }

    public function addValidateur(Validateur $validateur): self
    {
        if (!$this->validateurs->contains($validateur)) {
            $this->validateurs[] = $validateur;
        }

        return $this;
    }

    public function removeValidateur(Validateur $validateur): self
    {
        if ($this->validateurs->contains($validateur)) {
            $this->validateurs->removeElement($validateur);
        }

        return $this;
    }

    public function getNom(): ?string
    {
        return $this->nom;
    }

    public function setNom(string $nom): self
    {
        $this->nom = $nom;

        return $this;
    }

    public function getListeNomValidateurs()
    {
        $liste = [];

        foreach ($this->validateurs as $validateur) {
            $nom = $validateur->getValidateur()->getFullName();
            $liste[] = $nom;
        }

        return $liste;
    }

    public function triGroupeParOrdre()
    {
        $tab = [];

        foreach ($this->validateurs as $validateur) {
            if (count($tab) == 0) {
                $tab[] = $validateur;
            }
        }
    }
}

验证者:

<?php

namespace App\Entity;

use Gedmo\Sortable\Sortable;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\Collection;
use Gedmo\Mapping\Annotation\SortablePosition;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Bridge\Doctrine\Validator\Constraints\UniqueEntity;

/**
 * @ORM\Entity(repositoryClass="App\Repository\ValidateurRepository")
 */
class Validateur
{
    /**
     * @ORM\Id()
     * @ORM\GeneratedValue()
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @ORM\Column(type="integer")
     * @Gedmo\Mapping\Annotation\SortablePosition
     */
    private $ordre;

    // /**
    //  * @ORM\OneToOne(targetEntity="App\Entity\User", cascade={"persist", "remove"})
    //  * @ORM\JoinColumn(nullable=false)
    //  */
    // private $validateur;

    /**
     * @ORM\ManyToMany(targetEntity="App\Entity\GroupeValidateurs", mappedBy="validateurs")
     */
    private $groupeValidateurs;

    /**
     * @ORM\ManyToOne(targetEntity="App\Entity\User")
     * @ORM\JoinColumn(nullable=false)
     */
    private $validateur;



    public function __construct()
    {
        $this->groupeValidateurs = new ArrayCollection();
    }

    public function getId(): ?int
    {
        return $this->id;
    }

    public function getOrdre(): ?int
    {
        return $this->ordre;
    }

    public function setOrdre(int $ordre): self
    {
        $this->ordre = $ordre;

        return $this;
    }

    public function getValidateur(): ?User
    {
        return $this->validateur;
    }

    public function setValidateur(User $validateur): self
    {
        $this->validateur = $validateur;

        return $this;
    }

    /**
     * @return Collection|GroupeValidateurs[]
     */
    public function getGroupeValidateurs(): Collection
    {
        return $this->groupeValidateurs;
    }

    public function addGroupeValidateur(GroupeValidateurs $groupeValidateur): self
    {
        if (!$this->groupeValidateurs->contains($groupeValidateur)) {
            $this->groupeValidateurs[] = $groupeValidateur;
            $groupeValidateur->addValidateur($this);
        }

        return $this;
    }

    public function removeGroupeValidateur(GroupeValidateurs $groupeValidateur): self
    {
        if ($this->groupeValidateurs->contains($groupeValidateur)) {
            $this->groupeValidateurs->removeElement($groupeValidateur);
            $groupeValidateur->removeValidateur($this);
        }

        return $this;
    }
}

谢谢!

【问题讨论】:

    标签: php symfony doctrine dql


    【解决方案1】:

    您应该能够通过annotating 您的Groupe 实体实现您想要的结果:

    /**
     * @ORM\Entity(repositoryClass="App\Repository\GroupeValidateursRepository")
     */
    class GroupeValidateurs
    {
        // ...
    
        /**
         * @ORM\ManyToMany(targetEntity="App\Entity\Validateur", inversedBy="groupeValidateurs", cascade={"persist"})
         * @ORM\OrderBy({"ordre" = "ASC"})
         */
        private $validateurs;
    }
    

    然后您只需通过您的存储库检索您想要的组:

    $group = $groupeRepository->find($groupId);
    dump($group->getValidateurs());
    

    【讨论】:

    • 非常感谢,这正是我想要的!
    猜你喜欢
    • 2014-02-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-05-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多