1

为了从 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 ...
}
4

2 回答 2

1

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

于 2012-08-16T11:07:34.900 回答
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);
}

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

于 2012-08-16T08:56:22.607 回答