如何从symfony2中删除实体

时间:2012-08-04 15:16:25

标签: symfony doctrine

我的第一个symfony2项目是存储在数据库中的guest虚拟机列表(在事件中受邀)。我有

  • 创建了实体类Guest,包含所有变量(id,name,address,phone number等)
  • 在mysql db
  • 中创建了模式
  • 为树枝模板
  • 创建了“添加访客”的路线
  • 创建了一个formType

最后在Controller中使用“createGuest”方法,一切正常。

我无法从数据库中删除guest虚拟机。我已经阅读了网络上的每个教程,包括官方的Symfony2书;所有这一切都是:

删除对象

删除对象非常相似,但需要调用实体管理器的remove()方法:

$em->remove($product);
$em->flush();

关于如何将控制器deleteAction($ id)与twig模板连接,它没有说明(甚至“更新对象”部分缺少文档)。我想要做的是列出所有具有viewGuests操作和viewGuests树枝模板的客人,每行旁边都有一个删除图标,您应该单击该图标以删除条目。很简单,但我找不到任何文档,也不知道从哪里开始。

public function deleteGuestAction($id)
    {
        $em = $this->getDoctrine()->getEntityManager();
        $guest = $em->getRepository('GuestBundle:Guest')->find($id);

        if (!$guest) {
            throw $this->createNotFoundException('No guest found for id '.$id);
        }

        $em->remove($guest);
        $em->flush();

        return $this->redirect($this->generateUrl('GuestBundle:Page:viewGuests.html.twig'));
    }

3 个答案:

答案 0 :(得分:82)

Symfony非常聪明,并且知道如何自己制作find()

public function deleteGuestAction(Guest $guest)
{
    if (!$guest) {
        throw $this->createNotFoundException('No guest found');
    }

    $em = $this->getDoctrine()->getEntityManager();
    $em->remove($guest);
    $em->flush();

    return $this->redirect($this->generateUrl('GuestBundle:Page:viewGuests.html.twig'));
}

要在控制器中发送ID,请使用{{ path('your_route', {'id': guest.id}) }}

答案 1 :(得分:5)

DELETE FROM ... WHERE id = ...;

protected function templateRemove($id){
            $em = $this->getDoctrine()->getManager();
            $entity = $em->getRepository('XXXBundle:Templates')->findOneBy(array('id' => $id));

            if ($entity != null){
                $em->remove($entity);
                $em->flush();
            }
        }

答案 2 :(得分:3)

根据我的理解,你很难在模板中添加什么。

我将举例:

<ul>
    {% for guest in guests %}
    <li>{{ guest.name }} <a href="{{ path('your_delete_route_name',{'id': guest.id}) }}">[[DELETE]]</a></li>
    {% endfor %}
</ul>

现在发生的事情是迭代访客中的每个对象(如果您的对象集合另有命名,则必须重命名!),显示名称并放置正确的链接。路线名称可能不同。