为什么删除所有记录而不只是一个?

时间:2012-08-16 08:08:36

标签: php symfony doctrine-orm

要从Web服务中删除游戏会话,我们已定义以下控制器。

我希望删除一个Session实体,而不是从数据库中删除所有记录。

SessionController.php

/**
 * @Route("/{id}/")
 * @Method({"DELETE"})
 */
public function deleteAction($id)
{
    $repository = $this->getSessionRepository();
    $session = $repository->find($id);

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

    return new Response('', 200);
}

services.yml包含:

  sh.repository.session:
    class: ScavengerWebserviceBundle\Entity\SessionRepository
    factory_service: doctrine.orm.default_entity_manager
    factory_method: getRepository
    arguments:
      - 'ScavengerWebserviceBundle:Session'
/**
 * @return \Scavenger\WebserviceBundle\Entity\SessionRepository
 */
private function getSessionRepository()
{
    return $this->container->get('sh.repository.session');
}

该实体包含:

<?php

namespace Scavenger\WebserviceBundle\Entity;

use Scavenger\WebserviceBundle\Entity\Battlezone;

use Doctrine\ORM\Mapping as ORM;
use \Doctrine\ORM\Mapping\OneToOne;
use \Doctrine\ORM\Mapping\ManyToMany;
use \Doctrine\ORM\Mapping\JoinTable;
use \Doctrine\ORM\Mapping\JoinColumn;

/**
 * Scavenger\WebserviceBundle\Entity\Session
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="Scavenger\WebserviceBundle\Entity\SessionRepository")
 */
class Session
{

    const SESSION_ACTIVE = 0; //lol

    /**
     * @var integer $id
     *
     * @ORM\Column(name="id", type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    private $id;

    /**
     * @var string $name
     *
     * @ORM\Column(name="name", type="string", length=255)
     */
    private $name;

    /**
     * @var integer $mrX
     *
     * @ORM\Column(name="mrX", type="integer")
     */
    private $mrX;


     /**
     * @var integer $causer
     *
     * @ORM\Column(name="causer", type="integer")
     */
    private $causer = 0;


    /**
     * @var integer $statusCode
     *
     * @ORM\Column(name="status_code", type="integer", nullable=false)
     */
    private $statusCode = self::SESSION_ACTIVE;


    /**
     * @ManyToMany(targetEntity="Scavenger\WebserviceBundle\Entity\User", mappedBy="sessions", cascade={"all"})
     */
    private $users;

    /**
     * @OneToOne(targetEntity="Scavenger\WebserviceBundle\Entity\Battlezone", cascade={"all"})
     * @JoinColumn(name="battlezone_id", referencedColumnName="id")
     */
    private $battlezone;

    /**
     * @var integer
     * @ORM\Column(name="start", type="integer") 
     */
    private $start = 0;

    /**
     * @var integer
     * @ORM\Column(name="end", type="integer")
     */
    private $end = 0;


    //a bunch of setters and getters ...
}

2 个答案:

答案 0 :(得分:1)

这是因为你在$ users字段设置了“cascade = all”。我猜你在User实体的“sessions”字段上也有相同的级联,因此如果删除一些会话对象,所有与该对象相关的用户也将被删除,并且与这些用户相关的所有会话对象也将被删除。 / p>

答案 1 :(得分:0)

当您通过find($ id)调用时,它调用指向整个数据存储的对象,而它必须仅限于对象指向的数据存储中的1个实体。

model中创建'unsetData'(如果可能)。

SessionController.php

/**
 * @Route("/{id}/")
 * @Method({"DELETE"})
 */
public function deleteAction($id)
{
    $session = $this->getSessionRepository()->find($id);
    $session->unsetData(); // Logically, unset($session->dataToUnset);
    $em->persist();
    $em->flush();

    return new Response('', 200);
}

这是供参考。我没有尝试过这段代码但是,如果没有,那么你现在已经知道了路径,或者如果没有,请回复评论并将其排序!