Doctrine2 ArrayCollection错误
-
02-10-2019 - |
题
我正在尝试遵循学说文档的建议 这一页 - 初始用阵列汇总初始化类成员。对于文档中给出的示例,一切都很好。我正在尝试使用继承的班级进行,但会出现一个错误:
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
{
...
}
当我将构造函数移至继承类时,一切都很好。但是,将它们放在继承的抽象类中是多大的。为什么不起作用?是否可以?
解决方案
我的错。我塞满了映射。这是我现在正在使用的映射:
/**
* @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;
角色应该能够有很多父母和许多孩子
不隶属于 StackOverflow