私は3つのエンティティを持っています:
FeatureValue.php
<?php
namespace Webmuch\ProductBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Entity
*/
class FeatureValue
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\Column(type="string", length="100")
*/
protected $name;
/**
* @ORM\OneToMany(targetEntity="FeatureType", mappedBy="name")
*/
private $featuretype;
public function __construct()
{
$this->featuretype = new \Doctrine\Common\Collections\ArrayCollection();
}
FeatureType.php
<?php
namespace Webmuch\ProductBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Webmuch\ProductBundle\Entity\FeatureValue;
/**
* @ORM\Entity
*/
class FeatureType
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\Column(type="string", length=255, nullable=true)
*/
protected $title;
/**
* @ORM\ManyToOne(targetEntity="FeatureValue", inversedBy="featuretype",cascade={"persist"})
* @ORM\JoinColumn(name="feature_value_id", referencedColumnName="id")
*/
protected $name;
public function __construct()
{
$this->name = new \Doctrine\Common\Collections\ArrayCollection();
}
Product.php
<?php
namespace Webmuch\ProductBundle\Entity;
use Gedmo\Mapping\Annotation as Gedmo;
use Doctrine\ORM\Mapping as ORM;
use Doctrine\Common\Collections\ArrayCollection as ArrayCollection;
/**
* @ORM\Entity
* @ORM\Table()
* @ORM\HasLifecycleCallbacks
*/
class Product
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\ManyToMany(targetEntity="Store")
*/
protected $store;
/**
* @ORM\ManyToMany(targetEntity="Webmuch\CategoryBundle\Entity\Category")
*/
protected $category;
/**
* @Gedmo\Sluggable
* @ORM\Column(type="string", length=255)
*/
protected $title;
/**
* @Gedmo\Slug(updatable=false, unique=true)
* @ORM\Column(type="string", length=255)
*/
protected $slug;
/**
* @ORM\Column(type="integer")
*/
protected $quantity;
/**
* @ORM\Column(type="boolean")
*/
protected $active;
/**
* @ORM\Column(type="text", length="4000", nullable="true")
*/
protected $preview;
/**
* @ORM\ManyToMany(targetEntity="FeatureType")
* @ORM\JoinColumn(name="feature_type_id", referencedColumnName="id")
*/
protected $features;
public function __toString()
{
return $this->getTitle();
}
}
私の問題は、FeatureType に FeatureValue を追加すると、「Doctrine\Common\Collections\ArrayCollection は有効なエンティティまたはマップされたスーパー クラスではありません」というエラー クラスが表示されることです。
私のプロジェクトでは、私の Product エンティティに FeatureType とともに FeatureValue が必要です。
FeatureType で 2 つのプロパティ Size と Colour.Now を想定します。FeatureType Size で 3 つの FeatueValue Small、Medium、Large が指定され、FeatureType Colour で 3 つの FeatureValue Red、Green、Yello が指定されているとします。ここで、製品エンティティに FeatureType とその FeatureValue の両方を表示したいと考えています。
だから、誰でもできる方法を教えてください。私はたくさん試しましたが、成功しませんでした。