原则 持久 实体在实体管理器>持久化和单位工作>持久化之间更改



在我的symfony2/doctrine2应用程序中,我遇到了一个奇怪的情况,在持久化修改后的实体时,更改不会刷新到数据库中,我不明白为什么。

以下是我的代码:

$date = $subscription->getPaymentValidUntil()->format('d/m/Y');
$period = $payment->getDetail('period');
$validDate = $subscription->getPaymentValidUntil()
->add(newDateInterval($period == Subscription::MONTH ? 'P1M' : 'P1Y'))
;
$subscription->setPaymentValidUntil($validDate);
$this->em->persist($subscription);
exit(var_dump(array(
$date,
$this->em->getUnitOfWork()->getScheduledEntityUpdates(),
$subscription->getPaymentValidUntil(),
)));
$this->em->flush();

vardump的输出如下:

array (size=3)
0 => string '12/05/2015' (length=10)
1 => 
array (size=0)
empty
2 => 
object(DateTime)[2295]
public 'date' => string '2015-06-12 18:52:37' (length=19)
public 'timezone_type' => int 3
public 'timezone' => string 'Europe/Paris' (length=12)

如果我在vardump之前刷新或删除vardump,实际上,数据库中的日期值不会更改。为什么?

正如你所看到的,我在这个日期值上加了一个月,它反映在实体中,但没有计划更新。我该如何解决这个问题?

编辑:我深入研究了实体管理器持久化功能,发现当在Doctrine\ORM\EntityManager::persistent中转储实体时,日期是好的,但当在Doctorne\ORM\ UnitOfWork::persist中转储时,日期不知怎的被重新设置为原来的日期:

DoctrineORMEntityManager::persist:转储更新后的实体

public function persist($entity)
{
if ( ! is_object($entity)) {
throw ORMInvalidArgumentException::invalidObject('EntityManager#persist()' , $entity);
}
$this->errorIfClosed();
if ($entity instanceof Subscription) exit(var_dump($entity));
$this->unitOfWork->persist($entity);
}

条令\ORM\UnitOfWork::持久:转储未修改的实体:为什么

private function doPersist($entity, array &$visited)
{
if ($entity instanceof Subscription) exit(var_dump($entity));
$oid = spl_object_hash($entity);
if (isset($visited[$oid])) {
return; // Prevent infinite recursion
}
}

DateTime毕竟是对象,并且总是通过引用传递。所以,我强烈建议你这样编辑你的代码:

$period = $payment->getDetail('period');
$validDate = clone $subscription->getPaymentValidUntil();
$validDate->add(new DateInterval($period == Subscription::MONTH ? 'P1M' : 'P1Y'));
$subscription->setPaymentValidUntil($validDate);
$this->em->persist($subscription);
$this->em->flush();

通过这种方式,您可以确保将不同的对象传递给实体,并避免EntityManager中的任何细微错误。

相关内容

  • 没有找到相关文章

最新更新