[英]retrieve the Many side of association in Doctrine2
我有两个实体,一个是Role,另一个是User,我想要构建表单和报表以向其用户添加和显示每个角色,并创建一个具有Role的用户,因此其User:Role(一对多),我设法通过Doctrine 2向用户添加角色,但是我无法向用户显示以下每个角色的代码
<?php
/**
* Description of Role
* @Entity
* @Table=(name"Roles")
* @author alaaqashou
*/
class Role {
//put your code here
/**
*
* @var integer $id
* @Column(name="id", type="integer",nullable=false)
* @Id
* @GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @Column(length=100,nullable=false,unique=true)
* @var type
*/
private $name;
/**
* @OneToMany(targetEntity="User" ,mappedBy="Role")
* @var type
*/
private $users;
public function __construct() {
$this->users=new \Doctrine\Common\Collections\ArrayCollection();
}
public function getUsers() {
return $this->users;
}
public function setUsers($user) {
$this->users->add($user);
}
}
/**
* Description of User
*@Entity
* @Tabel(name="Users")
* @author alaaqashou
*/
class User {
//put your code here
/**
*
* @var integer $id
* @Column(name="id", type="integer",nullable=false)
* @Id
* @GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
*
* @Column(length=255,nullable=false,unique=true)
*
*
* @var type
*
*/
private $role;
function __construct() {
$this->created=new \DateTime(date("Y-m-d H:i:s"));
}
public function getRole() {
return $this->role;
}
public function setRole($role) {
$this->role = $role;
}
}
我收到通知:未定义的索引:尝试执行以下操作时出现角色错误
我的服务
public function listAllRole()
{
return $this->em->getRepository('sihha\Entity\Role')->findAll();
}
$roles=$this->roleService->listAllRole();
$users=$roles[0]->getUsers();
// I even tried $users=$roles[0]->getUsers()->toArray();
$user=$users[0];
请帮忙!!!
我认为您的问题出在注释上。 尝试替换mappedBy='Role'
宽度, mappedBy='role'
(即以小写形式输入“ role”)。
我只是在我的一个实体中尝试了mappedBy="Table"
,它给了我您似乎拥有的相同结果。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.