使用doctrine ORM(Symfony)正确创建ManyToMany递归/反身关系

时间:2015-06-08 13:56:19

标签: php database symfony doctrine-orm recursive-datastructures

我有一个名为Pointscomptage.php的实体:

class Pointscomptage

    {
        /**
         * @var integer
         *
         * @ORM\Column(name="id", type="integer", nullable=false)
         * @ORM\Id
         * @ORM\GeneratedValue(strategy="IDENTITY")
         */
        private $id;

        /**
         * @var string
         *
         * @ORM\Column(name="invariant", type="string", length=150, nullable=false)
         */
        private $invariant;

        /**
         * @var string
         *
         * @ORM\Column(name="nom", type="string", length=150, nullable=false)
         */
        private $nom;

        /**
         * @var string
         *
         * @ORM\Column(name="consoProduction", type="string", length=150, nullable=false)
         */
        private $consoProduction;

        /**
         * @var Typesenergie
         *
         * @ORM\ManyToOne(targetEntity="Typesenergie", inversedBy="pointscomptage")
         * @ORM\JoinColumn(name="typesenergie_id", referencedColumnName="id")
         */
        private $typesenergie;

        /** ... getters and setters */

我需要了解如何在此实体上创建 ManyToMany 递归自反关系。

也就是说, Pointscomptage可能没有(0)或很多(n)Pointscomptage

如何在同一个实体上建立这种关系?

修改

感谢 Jovan Perovic 回答并建议我找到的解决方案,我们需要尊重教义注释:

/**
     * @ORM\ManyToMany(targetEntity="Pointscomptage")
     * @ORM\JoinTable(name="pointscomptage_link_table",
     * joinColumns={
     *     @ORM\JoinColumn(name="pointscomptage_id", referencedColumnName="id")
     *   },
     *   inverseJoinColumns={
     *     @ORM\JoinColumn(name="id_pointscomptage2", referencedColumnName="id")
     *   }
     * )
     **/
    private $pointscomptages;

非常感谢你。

1 个答案:

答案 0 :(得分:1)

这可以通过与任何实体相同的方式完成。见official docs on @ManyToMany

例如:

/**
 * @ManyToMany(targetEntity="Pointscomptage")
 * @JoinTable(name="pointscomptage_link_table",
 *      joinColumns={@JoinColumn(name="id_pointscomptage1", referencedColumnName="id")},
 *      inverseJoinColumns={@JoinColumn(name="id_pointscomptage2", referencedColumnName="id")}
 *      )
 **/
private $pointscomptages;

此示例假定以下内容:

  • 这种关系是单向的。双向同样容易实现,并在上面的文档链接中进行了描述。
  • 连接表名为pointscomptage_link_table
  • 连接表pointscomptage_link_table包含两个列键:
    • id_pointscomptage1
    • id_pointscomptage2

希望这有点帮助...