这是一个非常非常简单的行为,但我找不到用学说来实现它的方法。我将解释它只用两个实体来降低复杂性。
有两个相关的作者(作者和书)像“一个作者拥有零或多个书籍”和“一本书由零或一个作者拥有”,我试图解开作者和他的一个作者之间的关系书籍(来自作者方面),期望数据库中的book.author_id字段设置为null。
实体定义如下:
作者
/**
* Author
*
* @ORM\Table()
* @ORM\Entity(repositoryClass="Poc\PocBundle\Entity\AuthorRepository")
*/
class Author
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
*
* @ORM\Column(name="name", type="string", length=255)
*/
private $name;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set name
*
* @param string $name
* @return Author
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* @ORM\OneToMany(targetEntity="Book", mappedBy="author", cascade={"persist", "remove"})
*/
private $books;
public function __construct()
{
$this->products = new ArrayCollection();
}
/**
* Add books
*
* @param \Poc\PocBundle\Entity\Book $books
* @return Author
*/
public function addBook(\Poc\PocBundle\Entity\Book $books)
{
$this->books[] = $books;
return $this;
}
/**
* Remove books
*
* @param \Poc\PocBundle\Entity\Book $books
*/
public function removeBook(\Poc\PocBundle\Entity\Book $books)
{
$this->books->removeElement($books);
}
/**
* Get books
*
* @return \Doctrine\Common\Collections\Collection
*/
public function getBooks()
{
return $this->books;
}
}
图书
/**
* Book
*
* @ORM\Table()
* @ORM\Entity(repositoryClass="Poc\PocBundle\Entity\BookRepository")
*/
class Book
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;
/**
* @var string
*
* @ORM\Column(name="name", type="string", length=255)
*/
private $name;
/**
* Get id
*
* @return integer
*/
public function getId()
{
return $this->id;
}
/**
* Set name
*
* @param string $name
* @return Book
*/
public function setName($name)
{
$this->name = $name;
return $this;
}
/**
* Get name
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* @ORM\ManyToOne(targetEntity="Author", inversedBy="books")
* @ORM\JoinColumn(name="author_id", referencedColumnName="id", onDelete="SET NULL")
*/
protected $author;
/**
* Set author
*
* @param \Poc\PocBundle\Entity\Author $author
* @return Book
*/
public function setAuthor(\Poc\PocBundle\Entity\Author $author = null)
{
$this->author = $author;
return $this;
}
/**
* Get author
*
* @return \Poc\PocBundle\Entity\Author
*/
public function getAuthor()
{
return $this->author;
}
}
在主控制器中,我执行以下操作。
检索作者
检索此作者拥有的图书
从作者中移除图书
坚持作者&冲洗
检索图书
获取作者...
作者仍然是一样的。在数据库中,此记录的字段book.author_id未按预期设置为NULL,但仍与作者相关。
控制器代码:
$Book = $this->getDoctrine()
->getRepository('PocPocBundle:Book')
->find('1');
$Author = $this->getDoctrine()
->getRepository('PocPocBundle:Author')
->find('1');
$Author->removeBook($Book);
$em = $this->getDoctrine()->getManager();
$em->persist($Author);
$em->flush();
echo "<pre>";
$Book = $this->getDoctrine()
->getRepository('PocPocBundle:Book')
->find('1');
\Doctrine\Common\Util\Debug::dump($Book);
die;
...和输出
object(stdClass)[286]
public '__CLASS__' => string 'Poc\PocBundle\Entity\Book' (length=25)
public 'id' => int 1
public 'name' => string 'El Quijote' (length=10)
public 'author' =>
object(stdClass)[293]
public '__CLASS__' => string 'Poc\PocBundle\Entity\Author' (length=27)
public '__IS_PROXY__' => boolean true
public '__PROXY_INITIALIZED__' => boolean true
public 'id' => int 1
public 'name' => string 'Cervantes' (length=9)
public 'books' => string 'Array(1)' (length=8)
在实体书(id = 1)的输出中,我们可以看到这些书仍与作者有关。
当然,我错过了一些东西,但我找不到差距。
答案 0 :(得分:2)
如果要删除作者和图书实体之间的关联,则应删除图书实体中的关联,并使用$ em-&gt; flush()将其保留。 $ em-&gt; persist($ entity)不用于删除实体。删除PHP对象中的关联并通过ORM刷新它们会删除数据库中的关联。
请在Doctrine的文档中查看:
我希望它对你有用。干杯!