【问题标题】:Validating arraycollection in symfony2在 symfony2 中验证数组集合
【发布时间】:2012-10-26 16:52:11
【问题描述】:

我是 Symfony2 + Doctrine 的新手,我正在寻找一种方法来验证 Arraycollection 中的唯一性。可能它已经回答了问题,但我不知道如何解决它。 我有一个带有 CallbackRelevamientosserviciosprestador 类:

namespace Prestadores\PrincipalBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Component\Validator\ExecutionContext;
/**
 * Prestadores\PrincipalBundle\Entity\Relevamientosserviciosprestador
 *
 * @ORM\Table(name="relevServiciosPrestador")
 * @ORM\Entity(repositoryClass="Prestadores\PrincipalBundle\Repository\RelevamientosserviciosprestadorRepository")*
 * @Assert\Callback(methods={"sonUnicosLosTiposDeReclamoq"})  
 */
class Relevamientosserviciosprestador
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;
    ....
    ....
    /**
     * @ORM\OneToMany(targetEntity="Atencionusuarioreclamo", mappedBy="relevamiento_id", cascade={"persist"})
     * @Assert\Valid 
     */
    private $reclamos;         
    ....
    ....
    public function __construct()
    {
        $this->personal = new ArrayCollection();
        $this->reclamos = new ArrayCollection();        
    }
    ....
    ....
     /*Acá intentaremos validar si los tipos de reclamo que se están cargando son únicos para ese relevamiento*/
    public function sonUnicosLosTiposDeReclamoq(ExecutionContext $context)
    {
        foreach ($this->reclamos as $reclamo){
            /*Here, I get all entities, not only those related to a Relevamientosserviciosprestador*/
            var_dump($reclamo->gettiporeclamo()->getnombre());
        }
    }

}

还有 Atencionusuarioreclamo 实体:

namespace Prestadores\PrincipalBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;


/**
 * Prestadores\PrincipalBundle\Entity\Atencionusuarioreclamo
 *
 * @ORM\Table(name="atencionUsuarioReclamo")
 * @ORM\Entity
 */
class Atencionusuarioreclamo
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var Atencionusuariosede
     *
     * @ORM\ManyToOne(targetEntity="Atencionusuariosede")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="nroSede", referencedColumnName="id")
     * })
     */
    private $nrosede;

    /**
     * @var relevamiento_id
     *
     * @ORM\ManyToOne(targetEntity="Relevamientosserviciosprestador")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="relevamiento_id", referencedColumnName="id")
     * })
     */
    private $relevamiento_id;

    /**
     * @var Prmreclamotipo
     *
     * @ORM\ManyToOne(targetEntity="Prmreclamotipo")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="tipoReclamo", referencedColumnName="id")
     * })
     * @Assert\NotBlank()     
     */
    private $tiporeclamo;
    ....
    ....
    ....
    ....


}

我想在给定的 sederelevamiento_id

中检查 tiporeclamo 的唯一性

我使用具有 "Atencionusuarioreclamo" 实体的子表单集合的表单创建或编辑 Relevamientosserviciosprestador。提交时,Relevamientosserviciosprestador 的回调会执行,但 $this->reclamos所有已保存的实体,而不仅仅是那些与 Relevamientosserviciosprestador 我正在编辑的内容。 这是预期的行为还是我错过了什么? 我还测试了How to validate unique entities in an entity collection in symfony2 中提到的方法 但是,它再次检查所有实体。

我也读过Doctrine2 ArrayCollection,但我不明白它是否能解决问题。
拜托,您能告诉我在坚持之前如何管理 ArrayCollection 中的唯一性吗?
我很抱歉我的英语不好
提前感谢
伊万

【问题讨论】:

    标签: symfony doctrine arraycollection validates-uniqueness-of


    【解决方案1】:

    php 的array array_unique ( array $array [, int $sort_flags = SORT_STRING ] )

    结合ArrayCollection->toArray()ArrayCollection->__construct()

    在你的情况下:

    $Atencionusuarioreclamo = 
        new ArrayCollection(array_unique($Atencionusuarioreclamo->toArray());
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-07-31
      • 1970-01-01
      • 2012-03-05
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多