首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在Zend框架2中使用MappedSuperclass的多对多的原则

在Zend框架2中使用MappedSuperclass的多对多的原则
EN

Stack Overflow用户
提问于 2015-08-03 00:12:33
回答 2查看 748关注 0票数 0

我对Doctrine2很陌生,并试图为以下DB结构创建实体:

我希望在机器类的一个属性中将所有机器部件作为数组。我试过这个:

代码语言:javascript
运行
复制
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吗?还是有办法解决我的案子?

EN

Stack Overflow用户

发布于 2015-08-03 18:06:46

第6.1章中的Doctrine2文档。映射超类中进一步阅读(由@Wilt引用):

..。此外,只有当映射的超类目前只在一个实体中使用时,才有可能出现多到多的关联.

这意味着在这种情况下ORM映射没有帮助。我不能同时通过一个MachineHasCylinder、MachineHasBelt和MachineHasGear三个实体通过MappedSupperclass收集数据。我认为使用DQL原生SQL是解决这个问题的唯一方法。

票数 0
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31777859

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档