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 エンティティを取得することもできます。しかし、親エンティティで同じことを行うと、親クラスと子クラスの両方を含む結果セットを受け取ります。