Php Symfony2&;教义2:移除元素不';行不通

Php Symfony2&;教义2:移除元素不';行不通,php,symfony,doctrine-orm,Php,Symfony,Doctrine Orm,我有一个关于Symfony2和doctrine的小项目,我正在尝试更新2个相关实体: 会员和汽车 $carMembers = $car->getMembers(); echo count($carMembers); // --> show 2 echo get_class(carMembers[0]); // --> show MyCars\WSBundle\Entity\Member $car->removeMember($member); $em->persis

我有一个关于Symfony2和doctrine的小项目,我正在尝试更新2个相关实体:

会员和汽车

$carMembers = $car->getMembers();
echo count($carMembers); // --> show 2
echo get_class(carMembers[0]); // --> show MyCars\WSBundle\Entity\Member
$car->removeMember($member);
$em->persist($car);
$em->flush();

$carMembers= $car->getMembers();
echo count($carMembers); // --> show 1
echo get_class(carMembers[0]); // --> show MyCars\WSBundle\CarsController !!!
以下是我的实体:

汽车

/**
 * @ORM\ManyToMany(targetEntity="Member", mappedBy="cars")
 */
private $members;

/**
 * Remove Member
 *
 * @param MyCars\WSBundle\Entity\Member $member
 */
public function removeMember(\MyCars\WSBundle\Entity\Member $member)
{
    $this->members->removeElement($member);
    $member->removeCar($this);
}
/**
 * @ORM\ManyToMany(targetEntity="Car", cascade={"persist"})
 * @ORM\JoinTable(name="cars_membres",
 * joinColumns={@ORM\JoinColumn(name="member_id", referencedColumnName="member_id")},
 * inverseJoinColumns={@ORM\JoinColumn(name="car_id", referencedColumnName="car_id")}
 * )
 */
private $cars;
成员

/**
 * @ORM\ManyToMany(targetEntity="Member", mappedBy="cars")
 */
private $members;

/**
 * Remove Member
 *
 * @param MyCars\WSBundle\Entity\Member $member
 */
public function removeMember(\MyCars\WSBundle\Entity\Member $member)
{
    $this->members->removeElement($member);
    $member->removeCar($this);
}
/**
 * @ORM\ManyToMany(targetEntity="Car", cascade={"persist"})
 * @ORM\JoinTable(name="cars_membres",
 * joinColumns={@ORM\JoinColumn(name="member_id", referencedColumnName="member_id")},
 * inverseJoinColumns={@ORM\JoinColumn(name="car_id", referencedColumnName="car_id")}
 * )
 */
private $cars;

我想你要找的是
关系选项

@ORM\ManyToMany(targetEntity="Car", cascade={"persist"}, orphanRemoval=true)

所以,当您从集合中删除项并刷新实体管理器时,它将从数据库中删除关系记录…

您使用哪个集合?您是否使用\document\arraycollection? 是否确实要删除相同的成员对象实例? 方法仅当对象是同一实例时才从集合中移除该对象

以下是方法(注意数组搜索方法中的最后一个参数(true):

public function removeElement($element)
{
  $key = array_search($element, $this->_elements, true);

  if ($key !== false) {
    unset($this->_elements[$key]);
    return true;
  }

  return false;
}

如果要使用函数addcontainsremoveElement

<?php

// ...

use Doctrine\Common\Collections\ArrayCollection;

class Car
{
    /**
     * @MongoDB\Id
     */
    protected $members;

    /**
     * General constructor
     */
    public function __construct()
    {
        $this->members = new ArrayCollection();
    }

    /**
     * @param Member $member
     * @return $this
     */
    public function addMember(Member $member)
    {
        if (!$this->hasMember($member)) {
            $this->members->add($member);
        }

        return $this;
    }

    /**
     * @param Member $member
     * @return $this
     */
    public function removeMember(Member $member)
    {
        if ($this->hasMember($member)) {
            $this->members->removeElement($member);
        }

        return $this;
    }

    /**
     * @return mixed
     */
    public function getMembers()
    {
        return $this->tags;
    }

    /**
     * @param Member $member
     * @return mixed
     */
    public function hasTag(Member $member)
    {
        return $this->members->contains($member);
    }
}

如果要删除对象(=数据库中的一行),只需使用
$em->remove($yourobject);$em->flush();
无需创建removeMember函数感谢您的回复,但我想将其保存在数据库中,我只想删除成员和汽车之间的关系。添加OrphanRemove时,我会出现以下错误:
未知属性OrphanRemoving;on annotation:Doctrine\ORM\Mapping\ManyToMany
仅适用于一对一或一对多y协会。