Doctrine:使用Symfony更新时的奇怪行为

时间:2017-01-25 12:21:29

标签: php symfony doctrine-orm

我有两个实体:

/**
 * @ORM\Entity
 * @ORM\Table(name="A")
 */ 
class A {
    /**
     * @ORM\Column(type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    protected $id;

    /**
     * @ORM\OneToMany(targetEntity="B", mappedBy="a")
     */
    protected $bs;
}

/**
 * @ORM\Entity
 * @ORM\Table(name="B")
 */ 
class B {
    /**
     * @ORM\Column(type="integer")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
     /**
     protected $id;

    * @ORM\ManyToOne(targetEntity="A", inversedBy="bs")
    * @ORM\JoinColumn(name="id_a", referencedColumnName="id")
    * @ORM\JoinColumn(onDelete="CASCADE")
    */
    protected $a;

}

在我的数据库中,表B有密钥(id,id_a)。 在编辑方法上,我通过id_b和id_a得到B,并且我在EntityManager上执行flush:

    $em = $this->getDoctrine()->getEntityManager();
    $b = $em->getRepository('B')->find(array('id' => $id_b,'a' => $id_a));

    $form = $this->createFormBuilder($b)
        ->add(...)
        ->getForm();

    $form->handleRequest($request);

    if ($form->isValid()) {
        $em->flush();
        ...

对所有B行应用更改,但不考虑id_b和id_a。

任何帮助都会受到赞赏, 提前谢谢

1 个答案:

答案 0 :(得分:0)

首先,您应该使用存储库方法出错。您正在使用方法 find 或方法的签名是:

    public function find($id);

您似乎在寻找findBy函数:

public function findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null);

请注意,此函数将返回集合而不是单个对象