2011-10-02 37 views
1

我有以下数据库结构:Doctrine2多对多不执行监听器事件

User  > UserRole  < Role 
UserId  UserRoleId  RoleId 
Name  UserId   Name 
      RoleId 
      Active 
      CreationDate 

而且我doctrine2类是这样定义的:

/** 
* @var Roles 
* 
* @ORM\ManyToMany(targetEntity="SecRole") 
* @ORM\JoinTable(name="SEC_USER_ROLE", 
*  joinColumns={@ORM\JoinColumn(name="SEC_USER_ID", referencedColumnName="SEC_USER_ID")}, 
*  inverseJoinColumns={@ORM\JoinColumn(name="SEC_ROLE_ID", referencedColumnName="SEC_ROLE_ID")} 
*  ) 
*/ 
private $userRoles; 

public function __construct() { 
    parent::__construct(); 
    $this->userRoles = new \Doctrine\Common\Collections\ArrayCollection(); 
} 

public function addSecRole(\myEntity\SecRole $role) 
{ 
    $exists = $this->userRoles->exists(function($key, $elem) use($role) { 
     return isset($elem) && $elem->getSecRoleCode() == $role->getSecRoleCode(); 
    }); 
    return !$exists && $this->userRoles->add($role); 
} 

要添加新角色给用户,我这样做:

$r = $rolerep->findOneBySecRoleCode('SystemAdmin'); 
    $u = $userrep->findOneByUserLogin('sysadmin'); 
    if (isset($r) && isset($u)) 
    { 
    if ($u->addSecRole($r)) { 
     $em->flush(); 
    } 
    } 

一切工作正常除了一件事。 SecUserRole实体不会调用生命周期事件!而且我的猜测是,由于Doctrine为自己“添加”了新的SecUserRole记录,因此它不会为其调用事件。

我正在收听prePersist,preUpdate,preDelete。既没有得到新的记录。我尝试过Flush,但它似乎并没有得到它。

有什么我失踪了,我怎么能解决这个问题?自己做插入?当然,这是一个解决方案,但这也让我自己也做了这些问题,这是我不想做的事情。

那么,在此先感谢 KAT LIM

回答

0

到目前为止,还没有找到最好的方式,但似乎学说假设你的加入表将“自动生成”则认为,它并没有,也不需要多于两个连接键(UserId,RoleId)。

我做了什么来解决它是停止使用ManyToMany,但使用OneToMany关系到SecUserRole表。因此,在addSecRole方法中,我插入了新对象,然后在外部刷新EM(如上面的示例)。

看来这是我能做的最好的方式。我从http://www.zendcasts.com/得到了这个想法,其中有一个专门为ManyToMany映射投射。

那么,希望这对所有人都有帮助