3

我正在尝试在 2 个实体之间进行双向关联。问题是我可以从书中获得他们的所有者,但从所有者那里我无法获得拥有的书籍。

这是代码的重要部分:

Acme\BookBundle\实体\书籍;

/**
 * @ORM\ManyToOne(targetEntity="Acme\UserBundle\Entity\User", inversedBy="owned_books")
 * @ORM\JoinColumn(name="owner_id", referencedColumnName="id")
 */
protected $owner;

/**
 * Get owner
 *
 * @return Acme\UserBundle\Entity\User 
 */
public function getOwner()
{
    return $this->owner;
}

Acme\UserBundle\实体\用户;

/**
 * @ORM\OneToMany(targetEntity="Acme\BookBundle\Entity\Book", mappedBy="owner")
 */
protected $owned_books;

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

/**
 * Get owned_books
 *
 * @return Doctrine\Common\Collections\Collection 
 */
public function getOwnedBooks()
{
    return $this->owned_books;
}

然后,要获取数据:

这个作品

$book = $this->getDoctrine()
  ->getRepository('BookBundle:Book')
  ->find(1);

$owner = $book->getOwner()->getFirstName();

这不起作用(给出致命错误:调用未定义的方法 Doctrine\ORM\PersistentCollection::getName() )

$owner = $this->getDoctrine()
    ->getRepository('UserBundle:User')
    ->find(1);

$books = $owner->getOwnedBooks()->getName();

有谁知道我做错了什么?先感谢您。

4

2 回答 2

10

$owner->getOwnedBooks() 是所有者的集合。尝试使用 foreach 循环遍历集合。

$books = $owner->getOwnedBooks();
foreach ($books as $book) {
    echo $book->getName() . ' <br/>';
} 
于 2012-06-14T08:43:03.690 回答
3

错误消息非常清楚:您正在尝试获取书籍集合的名称,而不是尝试获取单本书的名称。

于 2012-06-14T08:42:41.727 回答