0

symfony EasyAdminBundleにいくつかのカスタム アクションを追加しようとしています。フォーム ビューを問題なく追加しましたが、問題はこのフォーム POST アクションにあります。これは同じコントローラーの別のメソッドであり、うまく機能しますが、実行するpersist()flush()エンティティマネージャーの場合、何もしません。これは私のコードです。変更がデータベースに適用されないことを除いて、すべてが期待どおりに機能します。

/**
 * @Route("/product-segment/save/{id}", name="admin_product_segment_save")
 */
public function saveSegmentsAction($id)
{
    $em = $this->getDoctrine()->getManager();

    $product = $em->getRepository('AppBundle:product')->find($id);

    foreach ($product->getSegments() as $segment)
    {
        error_log("Product has segment " . $segment->getId());
    }

    $product->removeAllSegments();

    foreach ($product->getSegments() as $segment)
    {
        error_log("Now prod has  " . $segment->getId());
    }

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

    foreach ($this->getRequest()->request->all() as $post_var => $segment_id)
    {
        if ($post_var == 'segment_id')
        {
            $segment = $em->getRepository('AppBundle:Segment')->find($segment_id);
            $product->addSegment($segment);
        }
    }
    $em->persist($product);
    $em->flush();

    // redirect to the 'list' view of the given entity
    return $this->redirectToRoute('admin', array(
        'view'   => 'list',
        'entity' => 'Product',
    ));
}

編集:これは私のエンティティ関係です

/**
 * @ORM\ManyToMany(targetEntity="AppBundle\Entity\Segment", mappedBy="products", cascade={"all"})
 * @ORM\JoinTable(
 *      joinColumns={@ORM\JoinColumn(onDelete="CASCADE")},
 *      inverseJoinColumns={@ORM\JoinColumn(onDelete="CASCADE")}
 * )
 */
protected $segments;
4

1 に答える 1

0

まず、コード内で一度だけフラッシュを呼び出す必要があります。オブジェクトがあなたのやり方である場合:

$em = $this->getDoctrine()->getManager(); $product = $em->getRepository('AppBundle:product')->find($id);

再度保持する必要はありません。エンティティ マネージャは既にそのオブジェクトを持っています。何もしない動作について。ManyToMany リレーションが両側で定義されているかどうかを確認します。そして、あなたのメソッド removeAllSegments は、あなたがやりたいことをします。

http://doctrine-orm.readthedocs.org/projects/doctrine-orm/en/latest/reference/association-mapping.html

于 2015-10-21T13:04:08.840 に答える