doctrine2 ArrayCollection错误

时间:2010-09-09 23:53:06

标签: arraycollection doctrine-orm

我正在尝试遵循this page上的学说文档的建议 - 使用ArrayCollection初始化类成员。一切都适用于文档中给出的示例。我正在尝试使用继承的类,但得到一个错误说:

Class Doctrine\Common\Collections\ArrayCollection is not a valid entity or mapped super class

继承类:

/**
* @Entity
* @InheritanceType("JOINED")
* @DiscriminatorColumn(name="discr", type="string")
* @DiscriminatorMap({"user" = "App_User", "group" = "App_Group"})
*/

 abstract class App_Acl_Role_Abstract implements Zend_Acl_Role_Interface {

/**
 * @ManyToOne(targetEntity="App_Acl_Role_Abstract", inversedBy="children", cascade={"persist"})
 */
private $parents;

/**
 * @OneToMany(targetEntity="App_Acl_Role_Abstract", mappedBy="parents", cascade={"persist"})
 */
private $children;

public function __construct()
{
 $this->parents = new Doctrine\Common\Collections\ArrayCollection();
 $this->children = new Doctrine\Common\Collections\ArrayCollection();
}

}

继承类:

/**
 * @Entity
 * @Table(name="App_User")
 */
class App_User extends App_Acl_Role_Abstract
{
    ...
}

当我将构造函数移动到继承类时,一切正常。但是将它们放在继承的抽象类中会更加简洁。为什么不起作用?有可能吗?

1 个答案:

答案 0 :(得分:0)

我的坏。我填写了映射。这是我现在使用的映射:

/**
 * @ManyToMany(targetEntity="App_Acl_Role_Abstract", cascade={"persist"})
 * @JoinTable(name="role_parents",
 *      joinColumns={@JoinColumn(name="role_id", referencedColumnName="id")},
 *      inverseJoinColumns={@JoinColumn(name="parent_id", referencedColumnName="id", unique=true)}
 *      )
 */
private $parents;

/**
 * @ManyToMany(targetEntity="App_Acl_Role_Abstract", cascade={"persist"})
 * @JoinTable(name="role_children",
 *      joinColumns={@JoinColumn(name="role_id", referencedColumnName="id")},
 *      inverseJoinColumns={@JoinColumn(name="child_id", referencedColumnName="id", unique=true)}
 *      )
 */
private $children;

一个角色应该能够有很多父母和很多孩子