使用Doctrine实体的Matrix类型映射

时间:2015-11-25 11:09:35

标签: php mysql doctrine-orm zend-framework2 relational-database

我有点问题。我正在使用Doctrine 2实体对数据库结构进行建模,但我遇到了一个关系。

我需要在数据库中表示的是像表这样的矩阵:

| |A|B|C|D|
|A|  x
|B|x   x
|C|  x   x
|D|    x

表中显示的是其他优惠可用的优惠(x = true,空= false)。 我试图做的是与学说的多对多关系,希望这会生成一个映射表,但是Doctrine不这样做。 这是我的实体:

/** 
 * @ORM\Entity @ORM\HasLifecycleCallbacks 
 * @ORM\Entity(repositoryClass="Core\Repository\Main")
 * @ORM\Table(name="offer_availability") 
 */

class OfferAvailability implements JsonSerializable
{

    /**
     * @var int
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     * @ORM\Column(type="integer")
     */
    protected $id;

    /**
     * @var String
     * @ORM\Column(type="string")
     */
    protected $name;

    /**
     * @var \Doctrine\Common\Collections\Collection
     * @ORM\ManyToMany(targetEntity="Core\Entity\Offers\OfferAvailability", mappedBy="availableWith", inversedBy="availableWith", fetch="EXTRA_LAZY")
     */
    protected $availableWith; 

我知道我可以手动创建映射表实体并使用One to Many关系。但我想知道是否有更聪明的方法来解决这个问题。

1 个答案:

答案 0 :(得分:0)

没关系,我发现了这个问题。在这种情况下创建映射只会混淆Doctrine。删除映射和反演完全解决了这个问题:

/**
 * @var \Doctrine\Common\Collections\Collection
 * @ORM\ManyToMany(targetEntity="Core\Entity\Offers\OfferAvailability", fetch="EXTRA_LAZY")
 */
protected $availableWith;

这生成了一个映射表:

------------------------------------
|offeravailablity_offeravailability|
------------------------------------
|offeravailability_source          |
|offeravailability_target          |
------------------------------------