2012-07-09 137 views
2

我有一些麻煩與多級繼承:Doctrine2多層次繼承

第一級:

/** 
* @ORM\Table(name="request") 
* @ORM\Entity 
* @ORM\InheritanceType("JOINED") 
* @ORM\DiscriminatorColumn(name="discr", type="string") 
* @ORM\DiscriminatorMap({"base" = "Base", 
*      "delete" = "Delete", 
*      "contact" = "Contact"}) 
*/ 
class Requete 
{ 

第二級:

/** 
* @ORM\Table(name="base") 
* @ORM\Entity 
* @ORM\InheritanceType("JOINED") 
* @ORM\DiscriminatorColumn(name="discr", type="string") 
* @ORM\DiscriminatorMap({"base" = "Base", 
*      "prosante" = "ProSante", 
*      "pharmacie" = "Pharmacie", 
*      "hopital" = "Hopital"}) 
*/ 

abstract class Base extends Requete 
{ 

第三級:

/** 
* @ORM\Table(name="prosante") 
* @ORM\Entity 
*/ 

class ProSante extends Base 
{ 

當我t時記錄日誌ry插入一個新的「ProSante」:

INSERT INTO request (discr) VALUES (?) ({"1":"prosante"}) 
INSERT INTO prosante (id) VALUES (?) ({"1"}) 

它應該「插入基地...」之前,但它沒有。 字段discr只在請求表中,不在基表中,我不知道爲什麼。

如果有人有想法。

在此先感謝,

回答

4

我不知道什麼是錯。在試圖複製你的問題,我不能。

進入一個symfony的2.0.15項目,我用下面的實體

<?php 

namespace Peter\SandboxBundle\Entity; 

use Doctrine\ORM\Mapping as ORM; 

/** 
* @ORM\Table(name="request") 
* @ORM\Entity 
* @ORM\InheritanceType("JOINED") 
* @ORM\DiscriminatorColumn(name="discr", type="string") 
* @ORM\DiscriminatorMap({"base" = "Base"}) 
*/ 
class Requete 
{ 
    /** 
    * @var integer $id 
    * 
    * @ORM\Column(name="id", type="integer") 
    * @ORM\Id 
    * @ORM\GeneratedValue(strategy="AUTO") 
    */ 
    private $id; 

    protected $discr; 

    /** 
    * Get id 
    * 
    * @return integer 
    */ 
    public function getId() 
    { 
     return $this->id; 
    } 

    /** 
    * Set discr 
    * 
    * @param string $discr 
    */ 
    public function setDiscr($discr) 
    { 
     $this->discr = $discr; 
    } 

    /** 
    * Get discr 
    * 
    * @return string 
    */ 
    public function getDiscr() 
    { 
     return $this->discr; 
    } 
} 

/** 
* @ORM\Table(name="base") 
* @ORM\Entity 
* @ORM\InheritanceType("JOINED") 
* @ORM\DiscriminatorColumn(name="discr", type="string") 
* @ORM\DiscriminatorMap({"base" = "Base", 
*      "prosante" = "ProSante"}) 
*/ 
abstract class Base extends Requete {} 

/** 
* @ORM\Table(name="prosante") 
* @ORM\Entity 
*/ 

class ProSante extends Base {} 

然後安裝了DDL,它看起來像這樣(由doctrine:schema:update生產)

CREATE TABLE request (id INT AUTO_INCREMENT NOT NULL, discr VARCHAR(255) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB; 
CREATE TABLE base (id INT NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB; 
CREATE TABLE prosante (id INT NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB; 
ALTER TABLE base ADD CONSTRAINT FK_C0B4FE61BF396750 FOREIGN KEY (id) REFERENCES request(id) ON DELETE CASCADE; 
ALTER TABLE prosante ADD CONSTRAINT FK_420DF702BF396750 FOREIGN KEY (id) REFERENCES request(id) ON DELETE CASCADE 

再發一個簡單的命令來測試插入

// ... 

protected function execute(InputInterface $input, OutputInterface $output) 
{ 
    $p = new ProSante(); 
    $em = $this->getContainer()->get('doctrine')->getEntityManager(); 

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

    $output->writeln('All done'); 
} 

// ... 

當我看到「全部完成」控制檯,然後我檢查了數據庫直接,其結果被粘貼下面

mysql> select * from prosante; 
+----+ 
| id | 
+----+ 
| 1 | 
+----+ 
1 row in set (0.00 sec) 

mysql> select * from base; 
+----+ 
| id | 
+----+ 
| 1 | 
+----+ 
1 row in set (0.00 sec) 

mysql> select * from request; 
+----+----------+ 
| id | discr | 
+----+----------+ 
| 1 | prosante | 
+----+----------+ 
1 row in set (0.00 sec) 

不知道在哪裏可以從這裏走。

+0

好吧,這很奇怪,我將刪除我的模式並重新創建它們。 – nlaille 2012-07-10 07:53:33

+1

好的,問題解決了,當我更新我的架構原則並沒有改變prosante外鍵。我刪除了我的數據庫並重新創建它。非常感謝。 – nlaille 2012-07-10 08:05:35