我是Symfony2的新手。这个问题与Doctrine和FOSUserBundle有关。
我有以下基于FOSUserBundle创建的User.php实体和多对多的自引用。
<?php
namespace Pan100\MoodLogBundle\Entity;
use FOS\UserBundle\Entity\User as BaseUser;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Entity
* @ORM\Table(name="fos_user")
*/
class User extends BaseUser
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ManyToMany(targetEntity="User", mappedBy="hasAccessToMe")
**/
protected $hasAccessTo;
/**
* @ManyToMany(targetEntity="User", inversedBy="hasAccessTo")
* @JoinTable(name="access",
* joinColumns={@JoinColumn(name="id", referencedColumnName="id")},
* inverseJoinColumns={@JoinColumn(name="accessor_id", referencedColumnName="id")}
* )
**/
private $hasAccessToMe;
public function __construct()
{
parent::__construct();
$this->hasAccessTo = new \Doctrine\Common\Collections\ArrayCollection();
$this->hasAccessToMe = new \Doctrine\Common\Collections\ArrayCollection();
}
}
尝试更新缓存或删除时给出以下错误:
[Doctrine\Common\Annotations\AnnotationException]
[Semantical Error] The annotation "@ManyToMany" in property Pan100\MoodLog
Bundle\Entity\User::$hasAccessTo was never imported. Did you maybe forget
to add a "use" statement for this annotation?
这里有什么问题?什么是“使用声明”?
答案 0 :(得分:46)
您忘了在注释中添加@ORM\
前缀:
/**
* @ManyToMany(targetEntity="User", mappedBy="hasAccessToMe")
**/
应该是
/**
* @ORM\ManyToMany(targetEntity="User", mappedBy="hasAccessToMe")
**/
答案 1 :(得分:3)
你也可以单独导入每个注释 - 我喜欢的方式:
use Doctrine\ORM\Mapping\Entity;
use Doctrine\ORM\Mapping\ManyToMany;
// ...
/**
* @Entity
*/
class User
{
/**
* @ManyToMany(targetEntity="Thing")
*/
private $things;
// ...
}