문제

프로젝트에서 SonataAdminBundle로 시작하지만 문제가 발생하는 엔티티가 발생합니다.나는이 엔티티가있다 :

<?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'));
}
.

그러나이 오류가 발생했습니다 :

주의 사항 : 정의되지 않은 색인 : Ingenieros /var/www/html/pingenieros/vendor/sonata-project/doctrine- orm-admin-bundle/sonata/doctrineormadminbundle/guesser/filtertypeguesser.php. 64 행

내가 뭘 잘못하고 있니?

도움이 되었습니까?

해결책 2

NeverMind가 나쁜 었습니다.이 코드를 참조하십시오.

/**
 * 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 정의 전에 @ 을 알아 차리고 있습니다. 어쨌든 감사합니다

다른 팁

시도

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

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top