2015-11-27 22 views
0

我在symfony2/doctrine2项目中创建了以下实体(学校和电路),其中包含多对一(包含一个或多个学校的电路)双向关系。 这里是Schoool.orm.ymlcircuit.orm.yml定义学说夹具数据加载 - 插入缺失的值

我试图加载相应的数据固定为每个这样的实体,如下图所示:

//Circuit Fixture 
    public function load(ObjectManager $em) { 
      $newCirco = new Circonscription(); 
      $newCirco->setId(1); 
      $newCirco->setLibelle('Circuit1'); 

      $em->persist($newCirco); 
      $em->flush(); 

      $this->addReference('circo1', $newCirco); 
    } 


    //School Fixture 
    public function load(ObjectManager $em) { 
      //Ecoles - Circo 1 
      $ecole = new Etablissement(); 
      $ecole->setRne('0310211L'); 
      $ecole->setCirconscription($em->merge($this->getReference('circo1'))); 
      $ecole->setLibelle('FRANCE'); 
      $ecole->setAdresse('6 AVENUE DE Test'); 
      $ecole->setTelphone('05xxxxxxxx'); 
      $ecole->setEmail('[email protected]'); 

      $em->persist($ecole); 
      $em->flush(); 
      $this->addReference('ecole', $ecole); 
    } 

然而,我从学说NotNullConstraintViolationException相关完整性侵犯。

An exception occurred while executing 'INSERT INTO etablissement (rne, libe 
    lle, adresse, telphone, email, circo_id) VALUES (?, ?, ?, ?, ?, ?)' with pa 
    rams ["0310241U", null, null, null, null, null]: 
    SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'libelle' cann 
    ot be null 

尽管该值已在灯具中定义。 什么可能是此错误的来源?或为什么由教义生成的插入不包含值?

回答

1

在学校夹具尝试改变的setCirconscription()参数:

public function load(ObjectManager $em) { 

     $ecole = new Etablissement(); 
     $ecole->setRne('0310211L'); 
     $ecole->setCirconscription($this->getReference('circo1')); 

     /.../ 

} 

而且不要忘了加载Circuit FixtureSchool Fixture

+0

为什么与'$这个 - does'it工作> getReference() '而不是对象管理器?只为了解 –

+1

它的工作原理是因为你的类扩展了'AbstractFixture':'抽象夹具类有助于管理夹具类之间的引用,以便设置其他夹具之间的关系' – scoolnico