1

doctrine の InheritanceType JOINED に問題があります。親エンティティ 'template' と子エンティティ 'implementation' があります。

/**
 * Netvlies\Bundle\MisBundle\Entity\ItemTemplate
 *
 * @ORM\Entity
 * @ORM\InheritanceType("JOINED")
 * @ORM\DiscriminatorColumn(name="discriminator", type="string")
 * @ORM\DiscriminatorMap({"template" = "ItemTemplate", "implementation" = "Item"})
 */
class ItemTemplate
{
    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=255)
     */
    private $name;
...



/**
 * Netvlies\Bundle\MisBundle\Entity\Item
 *
 * @ORM\Entity
 * @ORM\HasLifecycleCallbacks
 */
class Item extends ItemTemplate
{    
    /**
     * @var \DateTime $created
     * 
     * @ORM\Column(name="created", type="datetime")
     */
    private $created;

    /**
     * @var \DateTime $updated
     * 
     * @ORM\Column(name="updated", type="datetime")
     */
    private $updated;
...

問題なく両方のエンティティを作成して保存できます。また、リポジトリの findall() 関数を使用して Item エンティティを取得することもできます。しかし、親エンティティで同じことを行うと、親クラスと子クラスの両方を含む結果セットを受け取ります。

4

0 に答える 0