我对Doctrine2很陌生,并试图为以下DB结构创建实体:
我希望在机器类的一个属性中将所有机器部件作为数组。我试过这个:
class Machine {
....
/**
* @var array
* @ORM\OneToMany(targetEntity="MachineHasPart", mappedBy="machine", cascade={"persist", "remove"}, orphanRemoval=TRUE)
*/
private $parts;
....
public function getParts () {
return array_map(
function ($machineHasPart) {
return $machineHasPart->getPart();
},
$this->parts->toArray()
);
}
}
其中MachineHasPart
是中间实体/表(如machineHasCylinder
等)的@MappedSuperclass
,但是它失败了:
执行'SELECT从machineHasPart t0‘时发生异常。
我应该重组我的数据库以便在这里使用ORM吗?还是有办法解决我的案子?
发布于 2015-08-03 18:06:46
在第6.1章中的Doctrine2文档。映射超类中进一步阅读(由@Wilt引用):
..。此外,只有当映射的超类目前只在一个实体中使用时,才有可能出现多到多的关联.
这意味着在这种情况下ORM映射没有帮助。我不能同时通过一个MachineHasCylinder、MachineHasBelt和MachineHasGear三个实体通过MappedSupperclass收集数据。我认为使用DQL或原生SQL是解决这个问题的唯一方法。
https://stackoverflow.com/questions/31777859
复制相似问题