这是我的实体:
/**
* @ORM\Table(name="Animal")
* @ORM\HasLifecycleCallbacks
*/
class Animal {
/**
* @var integer $id
*
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @var localizedcontent $lctitle
*
* @ORM\ManyToOne(targetEntity="localizedcontent",fetch="EAGER", cascade={"persist"})
* @ORM\JoinColumn(name="lcTitle", referencedColumnName="pkId", nullable=false)
*/
private $lctitle;
/**
* @var localizedcontent $lcdescription
*
* @ORM\ManyToOne(targetEntity="localizedcontent",fetch="EAGER", cascade={"persist"})
* @ORM\JoinColumn(name="lcDescription", referencedColumnName="pkId", nullable=false)
*/
private $lcdescription;
/**
* @ORM\PostLoad
*/
public function postLoad(){
$lct = $this->lctitle;
$lcd = $this->lcdescription;
}
这是我的dql:
SELECT a,lct FROM Animal JOIN e.lctitle lct WHERE a.id=:id
当我启动xdebug时,它告诉我lcdescription是一个代理对象而lctitle不存在。我不知道为什么。 我认为postLoad事件太早了,因为此时没有加载本地化内容,对吧?是否有另一个用于读取与动物对象相关的lctitle值的侦听器?
由于
答案 0 :(得分:0)
Doctrine始终返回代理。这些类继承自实体类。如果您声明关系受保护而不是私有,则可能有所帮助。
/**
* @var localizedcontent $lctitle
*
* @ORM\ManyToOne(targetEntity="localizedcontent",fetch="EAGER", cascade={"persist"})
* @ORM\JoinColumn(name="lcTitle", referencedColumnName="pkId", nullable=false)
*/
protected $lctitle;
或者你可以写一个getter并在你的后加载函数中调用它
public function getLctitle() {
return $this->lctitle;
}
public function getLcdescription() {
return $this->lcdescription;
}
/**
* @ORM\PostLoad
*/
public function postLoad(){
$lct = $this->getLctitle();
$lcd = $this->getLcdescription();
}