2

使用 Symfon2.0 和 Doctrine,我正在尝试执行以下操作:

  1. 在数据库中插入新行
  2. 在插入的那一刻,自动生成一个代码并插入它。
  3. 该代码与表的 ID 有关。就像是<something>/row_id

我怎样才能轻松做到这一点?

我一直在尝试 Doctrine Livecycle 回调。但:

  • PrePersist 仍然没有 ID。
  • PostPersist 有 ID,但不知何故,插入已经完成,虽然我可以从实体设置任何属性,但我不知道如何使其“再次”持久保存到数据库中。

那边有什么线索吗?

还有其他正确的方法吗?

4

1 回答 1

1

在您的创建控制器中:

if ($form->isValid()) {
        $em = $this->getDoctrine()->getManager();
        $em->persist($entity);
        $em->flush();

        $entity->setCode($code);
        $em->persist($entity);
        $em->flush();

        return $this->redirect($this->generateUrl('entity_show'
           ,array('id' => $entity->getId())));
    }

第二个块 ($entity->setCode...) 是您需要添加的内容,需要根据您的目的进行定制

或者,您可以使用侦听器:

<?php

namespace ormed\ormedBundle\Listener;

use Doctrine\ORM\Event\OnFlushEventArgs; use
Symfony\Component\DependencyInjection\Container;

class LastModifiedListener {

  private $container;

  public function __construct(Container $container){$this->container = $container;}

  public function onFlush(OnFlushEventArgs $eventArgs)
  {
      $entityManager = $eventArgs->getEntityManager();
      $unitOfWork = $entityManager->getUnitOfWork();

      foreach ($unitOfWork->getScheduledEntityInsertions() AS $entity) {
          $entity->setCode( $code );

          $entityManager->persist($entity);
          $classMetadata = $entityManager->getClassMetadata(get_class($entity));
          $unitOfWork->recomputeSingleEntityChangeSet($classMetadata, $entity);
} } }
于 2012-12-10T23:47:09.693 回答