在数据库中,我有两个相关的表。
AppBooking
AppBookingService
AppBookingService具有AppBooking的外键
我使用此方法在第一张表和第二张表中进行插入。
public function bookingExecute($data){
try{
$this->em->beginTransaction();
$appBooking = $this->_fillAppBooking($data);
$this->em->persist($appBooking);
if(array_key_exists("appService",$data) && is_array($data['appService']) && count($data['appService']) > 0){
foreach($data['appService'] as $bookingService){
$appBookingService = $this->_fillAppBookingService($bookingService,$appBooking);
$this->em->persist($appBookingService);
$this->em->flush();
}
}
$this->em->flush();
$this->em->commit();
return $appBooking;
}catch (\Exception $ex){
$this->em->rollback();
throw new BookingException("",BookingError::BOOKING_QUERY_ERROR);
}
}
数据正确写入
然后,在同一个http请求中,我调用下面的方法,以便在我的实体中拥有AppBooking Service数据
$appBooking = $this->bookingService->findOne($id);
我得到的AppBooking实体不包含AppBookingService的问题
方法
$appBooking->getServices()->count()
返回0
如果我在另一个http请求中拨打相同的电话,则会得到理想的结果。
好像教义没有在同一请求中更新实体
这是AppBooking的一部分
/**
* @var Collection
* @ORM\OneToMany(targetEntity="AppBookingService", mappedBy="idBooking")
*/
private $services;
public function __construct() {
$this->services = new ArrayCollection();
}
这是AppBookingService的一部分
/**
* @var \Entity\Entity\AppBooking
*
* @ORM\ManyToOne(targetEntity="Entity\Entity\AppBooking", inversedBy="services")
* @ORM\JoinColumns({
* @ORM\JoinColumn(name="ID_BOOKING", referencedColumnName="ID_BOOKING", nullable=true)
* })
*/
private $idBooking;
答案 0 :(得分:1)
这是因为运行时
$appBooking = $this->bookingService->findOne($id);
该实体是从其内部代理缓存中获取的。没有执行数据库查询来获取实体的数据。其已加载的关联也是如此。 代理缓存在执行http请求期间有效。
要解决此问题,您必须手动更新$services
集合或 refresh 实体。
$this->em->refresh($appBooking);
从数据库刷新实体的持久状态,覆盖所有尚未持久的本地更改。
您还可以 clear 在之前调用findOne()方法。
$this->em->clear();
清除EntityManager。当前由此EntityManager管理的所有实体都已分离。
参考