2013-11-15 13 views
0

我在我的项目中以开头,但我遇到了一个问题获取相关实体。我有这样的实体:从相关实体获取值会导致错误

<?php 

namespace PI\ProyectoBundle\Entity; 

use Doctrine\ORM\Mapping as ORM; 
use Doctrine\ORM\Event\LifecycleEventArgs; 

/** 
* @ORM\Entity 
* @ORM\Table(name="proyectos") 
* @ORM\HasLifecycleCallbacks 
*/ 
class Proyectos { 

    /** 
    * @ORM\Id 
    * @ORM\Column(type="integer") 
    */ 
    protected $id; 

    /** 
    * @ORM\Column(type="string", length=45, unique=true, nullable=false) 
    */ 
    protected $nombre; 

    /** 
    * @ORM\Column(type="boolean", nullable=true) 
    */ 
    protected $estado; 

    /** 
    * @ORM\Column(type="string", length=45, nullable=false) 
    */ 
    protected $pais; 

    /** 
    * @ORM\Id 
    * @ORM\ManyToOne(targetEntity="PI\ClienteBundle\Entity\Clientes", cascade={"all"}) 
    * @ORM\JoinColumn(name="cliente", referencedColumnName="id") 
    */ 
    protected $clientes; 

    /** 
    * @ORM\ManyToMany(targetEntity="PI\CentroBundle\Entity\Centros", inversedBy="proyectos", cascade={"persist"}) 
    * @ORM\JoinTable(name="proyectos_has_centros", 
    *  joinColumns={@ORM\JoinColumn(name="proyectos_id", referencedColumnName="id"), 
    *     @ORM\JoinColumn(name="proyectos_cliente", referencedColumnName="cliente")}, 
    *  inverseJoinColumns={@ORM\JoinColumn(name="centros_id", referencedColumnName="id")} 
    *  ) 
    */ 
    protected $centros; 

    /** 
    * ORM\ManyToMany(targetEntity="Application\Sonata\UserBundle\Entity\User", cascade={"persist"}) 
    * ORM\JoinTable(name="proyectos_has_system_user", 
    *  joinColumns={@ORM\JoinColumn(name="proyectos_id", referencedColumnName="id"), 
    *     @ORM\JoinColumn(name="proyectos_cliente", referencedColumnName="cliente")}, 
    *  inverseJoinColumns={@ORM\JoinColumn(name="system_user_id", referencedColumnName="id")} 
    *  ) 
    */ 
    protected $ingenieros; 

    public function __construct() { 
     $this->centros = new \Doctrine\Common\Collections\ArrayCollection(); 
     $this->ingenieros = new \Doctrine\Common\Collections\ArrayCollection(); 
    } 

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

    public function setNombre($nombre) { 
     $this->nombre = $nombre; 
    } 

    public function getNombre() { 
     return $this->nombre; 
    } 

    public function setEstado($estado) { 
     $this->estado = $estado; 
    } 

    public function getEstado() { 
     return $this->estado; 
    } 

    public function setPais($pais) { 
     $this->pais = $pais; 
    } 

    public function getPais() { 
     return $this->pais; 
    } 

    public function setClientes(\PI\ClienteBundle\Entity\Clientes $clientes) { 
     $this->clientes = $clientes; 
    } 

    public function getClientes() { 
     return $this->clientes; 
    } 

    public function setCentros(\PI\CentroBundle\Entity\Centros $centros) { 
     $this->centros[] = $centros; 
    } 

    public function getCentros() { 
     return $this->centros; 
    } 

    public function setIngenieros(\BIT\UserBundle\Entity\User $ingenieros) { 
     $this->ingenieros[] = $ingenieros; 
    } 

    public function getIngenieros() { 
     return $this->ingenieros; 
    } 

    /** 
    * @ORM\PrePersist 
    */ 
    public function prePersist(LifecycleEventArgs $eventArgs) { 
     $em = $eventArgs->getEntityManager(); 
     $q = $em->createQuery('SELECT MAX(p.id) FROM PIProyectoBundle:Proyectos p'); 
     $id = $q->getSingleResult(\Doctrine\ORM\Query::HYDRATE_SINGLE_SCALAR); 
     $this->id = $id + 1; 
    } 

} 

这是我如何配置过滤器ProyectoAdmin.php类:

protected function configureDatagridFilters(DatagridMapper $filter) { 
    $filter 
      ->add('nombre', null, array('label' => 'Nombre')) 
      ->add('estado', null, array('label' => 'Estado')) 
      ->add('pais', null, array('label' => 'País')) 
      ->add('clientes', null, array('label' => 'Asignar Clientes')) 
      ->add('ingenieros', null, array(), null, array('expanded' => true, 'multiple' => true)) 
      ->add('centros', null, array('label' => 'Asignar Centros')); 
} 

但我得到这个错误:

Notice: Undefined index: ingenieros in /var/www/html/pingenieros/vendor/sonata-project/doctrine-orm-admin-bundle/Sonata/DoctrineORMAdminBundle/Guesser/FilterTypeGuesser.php line 64

我做错了什么?

回答

0

没关系是我不好,看到这样的代码:

/** 
* ORM\ManyToMany(targetEntity="Application\Sonata\UserBundle\Entity\User", cascade={"persist"}) 
* ORM\JoinTable(name="proyectos_has_system_user", 
*  joinColumns={@ORM\JoinColumn(name="proyectos_id", referencedColumnName="id"), 
*     @ORM\JoinColumn(name="proyectos_cliente", referencedColumnName="cliente")}, 
*  inverseJoinColumns={@ORM\JoinColumn(name="system_user_id", referencedColumnName="id")} 
*  ) 
*/ 
protected $ingenieros; 

应该是:

/** 
* @ORM\ManyToMany(targetEntity="Application\Sonata\UserBundle\Entity\User", cascade={"persist"}) 
* @ORM\JoinTable(name="proyectos_has_system_user", 
*  joinColumns={@ORM\JoinColumn(name="proyectos_id", referencedColumnName="id"), 
*     @ORM\JoinColumn(name="proyectos_cliente", referencedColumnName="cliente")}, 
*  inverseJoinColumns={@ORM\JoinColumn(name="system_user_id", referencedColumnName="id")} 
*  ) 
*/ 
protected $ingenieros; 

通知的@ORM定义,那是无论如何谢谢

0

尝试

->add('ingenieros', 'entity', array(
        'class' => 'AcmeMyBundle:Entity', //your ingenieros entity 
        'property' => 'name', // any class property 
        'multiple' => true, 
           'expanded' => true))