我无法在symfony2中以嵌入的形式写入数据库

时间:2015-10-27 19:59:29

标签: php symfony doctrine

我使用symfony2处理已嵌入的表单,但我有这个错误:

  

GestionResiduos \ EmpresaExternaBundle \ Entity \ Transportista类型的实体通过外国实体GestionResiduos \ EmpresaExternaBundle \ Entity \ EmpresaExterna具有身份,但此实体本身没有身份。您必须在相关实体上调用EntityManager#persist(),并确保在尝试持久化之前生成标识符' GestionResiduos \ EmpresaExternaBundle \ Entity \ Transportista'。如果生成后插入ID(例如MySQL自动增量或PostgreSQL SERIAL),这意味着您必须在两个持久操作之间调用EntityManager#flush()。

我有两个名为EmpresaExterna.php和Transportista.php的实体,其中有一个从transportista到exmpresaexterna的外键,所以我将一个嵌入的表单插入到两个表中,但我可以这样做。

这是我的EmpresaExterna.php代码:

<?php 

namespace GestionResiduos\EmpresaExternaBundle\Entity;

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

/**
*@ORM\Entity(repositoryClass="GestionResiduos\EmpresaExternaBundle\Entity\EmpresaExternaRepository")    */

class EmpresaExterna
{
/**
* @ORM\Id
* @ORM\column(type="string", length=80) 
*/

protected $nombreEmpresa;

/**
* @ORM\column(type="string", length=60) 
*/  

protected $comuna;

/**
* @ORM\column(type="string", length=60) 
*/  

protected $correo;

/**
* @ORM\column(type="string", length=20) 
*/  

protected $telefono;

/**
* @ORM\column(type="string", length=60) 
*/  

protected $ciudad;

/**
* @ORM\column(type="string", length=100) 
*/  

protected $direccion;

/**
* @ORM\column(type="string", length=20) 
*/  

protected $rut;

/**
* @ORM\column(type="string", length=20) 
*/  

protected $numeroSidrep;

显然包括了吸气剂和制定者。

对于Transportista.php:

<?php 

namespace GestionResiduos\EmpresaExternaBundle\Entity;

use Doctrine\ORM\Mapping as ORM;

/**
* @ORM\Entity(repositoryClass="EmpresaExternaRepository")
*/
class Transportista
{
/**
* @ORM\Id
* @ORM\ManyToOne(targetEntity="GestionResiduos\EmpresaExternaBundle\Entity\EmpresaExterna")
* @ORM\JoinColumn(name="nombreEmpresa_id", referencedColumnName="nombreEmpresa")
*/

protected $nombreEmpresa;

我的表格是RegistroTransportistaType.php和RegistroEmpresaExternaType:

<?php
// src/Gestionresiudos/EmpresaExternaBundle/Form/RegistroResiduoType.php

namespace Gestionresiduos\EmpresaExternaBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;

class RegistroTransportistaType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options)
{

    $builder
        ->add('nombreEmpresa', new RegistroEmpresaExternaType())
        ->add('registrar', 'submit')
        ;
}

public function setDefaultOptions(OptionsResolverInterface $resolver)
{

    $resolver->setDefaults(array('data_class' => 'Gestionresiduos\EmpresaExternaBundle\Entity\Transportista'));

}

public function getName()
{
    return 'gestionresiduos_empresaexternabundle_registrotransportistatype';
}
} 

RegistroEmpresaExternaType:     

namespace Gestionresiduos\EmpresaExternaBundle\Form;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolverInterface;

class RegistroEmpresaExternaType extends AbstractType
{
public function buildForm(FormBuilderInterface $builder, array $options)
{

    $builder
        ->add('nombreEmpresa')
        ->add('comuna')
        ->add('correo')
        ->add('telefono')
        ->add('ciudad')
        ->add('direccion')
        ->add('rut')
        ->add('numeroSidrep')
        ;
}

public function setDefaultOptions(OptionsResolverInterface $resolver)
{

    $resolver->setDefaults(array('data_class' => 'Gestionresiduos\EmpresaExternaBundle\Entity\EmpresaExterna'));

}

public function getName()
{
    return 'gestionresiduos_empreasexternabundle_registroempreasexternatype';
}
}

我的控制器是:

public function nuevoTransportistaAction(Request $request)
{       
    $transportista = new Transportista();
    $empresaExterna = new EmpresaExterna();

    $formulario = $this->createForm(new RegistroTransportistaType(), $transportista);
    $formulario->handleRequest($request);

    if($formulario->isValid())
    {
        //guardar la info en la base de datos
        //setear el nombre de la empresa
        $em = $this->getDoctrine()->getManager();


        // $transportista->getNombreEmpresa();
        $em->persist($transportista);
        $em->flush();
        //return $this->redirect($this->generateUrl('inicio')); 
    }

    return $this->render('EmpresaExternaBundle:Default:registroTransportista.html.twig', array('formulario' => $formulario->createView()));   
}

我发现另一个解释类似的帖子,但他们使用onetomany whit inversedBy进入表格。

最后这是我在树枝上的表格:

    {#src/Gestionresiduos/SolicitudIngresoBundle/Resources/views/Default/solicitaringreso.html.twig #}
{% extends '::frontend.html.twig' %}

{% block id 'usuario' %}
{% block title %}Registro de nuevo transportista{% endblock %}

{% block article %}
<h1>{{ block('title') }}</h1>

{{ form_start(formulario)}}
    {{ form_errors(formulario)}}

    <div>
    {{ form_label(formulario.nombreEmpresa.nombreEmpresa, 'Ingrese el nombre de la empresa') }}
    <span>{{ form_widget(formulario.nombreEmpresa.nombreEmpresa)}}</span><br>
    </div>

    <div>
    {{ form_label(formulario.nombreEmpresa.comuna, 'Ingrese comuna') }}
    <span>{{ form_widget(formulario.nombreEmpresa.comuna)}}</span>
    </div>


    <div>
    {{ form_label(formulario.nombreEmpresa.correo, 'Ingrese dirección email') }}
    <span>{{ form_widget(formulario.nombreEmpresa.correo)}}</span><br>
    </div>


    <div>
    {{ form_label(formulario.nombreEmpresa.telefono, 'Telefono') }}
    <span>{{ form_widget(formulario.nombreEmpresa.telefono)}}</span><br>
    </div>


    <div>
    {{ form_label(formulario.nombreEmpresa.ciudad, 'Ingrese ciudad') }}
    <span>{{ form_widget(formulario.nombreEmpresa.ciudad)}}</span><br>
    </div>

    <div>
    {{ form_label(formulario.nombreEmpresa.direccion, 'Indique dirección')}}
    <span>{{ form_widget(formulario.nombreEmpresa.direccion)}}</span><br>   
    </div>

    <div>
    {{ form_label(formulario.nombreEmpresa.rut, 'Ingrese el rut de la empresa') }}
    <span>{{ form_widget(formulario.nombreEmpresa.rut)}}</span><br>
    </div>

    <div>
    {{ form_label(formulario.nombreEmpresa.numeroSidrep, 'Ingrese el número SIDREP') }}
    <span>{{ form_widget(formulario.nombreEmpresa.numeroSidrep)}}</span><br>
    </div>

     <div>
    {{ form_widget(formulario.registrar) }}
    </div>
    {{ form_rest(formulario) }}
{{ form_end(formulario)}}

{% endblock %}
{% block aside %}{% endblock %}

对不起,给出了重大解释。我希望你能帮助我。谢谢!

2 个答案:

答案 0 :(得分:1)

问题是您是在保留父实体(Transportista)而不先保留您的子实体(EmpresaExterna)。因为它还没有id(这是一个新的/非管理的),Doctrine无法映射它。

在你的控制器中试试这个:

    $em->persist($transportista->getNombreEmpresa());
    $em->persist($transportista);
    $em->flush();

答案 1 :(得分:0)

更改以下代码:

/**
* @ORM\Id
* @ORM\ManyToOne(targetEntity="GestionResiduos\EmpresaExternaBundle\Entity\EmpresaExterna")
* @ORM\JoinColumn(name="nombreEmpresa_id", referencedColumnName="nombreEmpresa")
*/

protected $nombreEmpresa;

对此:

/**
* @ORM\Id
* @ORM\ManyToOne(targetEntity="GestionResiduos\EmpresaExternaBundle\Entity\EmpresaExterna", cascade={"persist"})
* @ORM\JoinColumn(name="nombreEmpresa_id", referencedColumnName="nombreEmpresa")
*/

protected $nombreEmpresa;

这将允许您只保留主实体,并且所有相关实体也将被保存。

$em->persist($transportista);

您可能需要在nombreEmpresa关系的主要实体的addMethod中添加更多代码。