gpt4 book ai didi

php - Doctrine DBAL 可以与 ORM Query Builder 混合使用吗?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:34:51 24 4
gpt4 key购买 nike

我正在尝试使用 ORM 创建查询生成器。但是我偶然发现了一个与 2 个可能的表有关系的实体的字段。使用这种结构,(恕我直言)不可能将其映射到实体本身。

╔═══════╗      ╔═══════╗       ╔═══════╗
║ ValB ║ ║ Main ║ ║ ValC ║
╠══╦════╣ ╠══╦════╣ ╠══╦════╣
║ *║ pk ║-- + ║ *║ pk ║ +---║ *║ pk ║
╠══╬════╣ | ╠══╬════╣ | ╠══╬════╣
║ ║ ║ +--║ ║v_id║---+ ║ ║ ║
╠══╬════╣ ╠══╬════╣ ╠══╬════╣
║ ║ ║ ║ ║ ║ ║ ║ ║
╚══╩════╝ ╚══╩════╝ ╚══╩════╝

是否可以将 DBAL QueryBuilder 与 ORM QueryBuilder 混合使用,或者仍将主要在代码中使用 ORM QueryBuilder 的任何其他方式。

附言。我没有设计数据库,我只是优化它。对此感到抱歉:(

最佳答案

不,它没有意义,因为以后的 ORM 必须将结果映射到对象。您不能将 ValBValC 都映射到 Main

中的同一属性

要正确地做到这一点,Main 表中应该有单独的字段用于ValBValC 关系。即使它们具有相同的值。像这样

╔═══════╗      ╔════════╗       ╔═══════╗
║ ValB ║ ║ Main ║ ║ ValC ║
╠══╦════╣ ╠══╦═════╣ ╠══╦════╣
║ *║ pk ║-- + ║ *║ pk ║ +---║ *║ pk ║
╠══╬════╣ | ╠══╬═════╣ | ╠══╬════╣
║ ║ ║ +--║ ║vB_id║ | ║ ║ ║
╠══╬════╣ ╠══╬═════╣ | ╠══╬════╣
║ ║ ║ ║ ║vC_id║---+ ║ ║ ║
╚══╩════╝ ╚══╩═════╝ ╚══╩════╝

您可以复制v_id列,然后在Doctrine中进行适当的映射。

关于php - Doctrine DBAL 可以与 ORM Query Builder 混合使用吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37741951/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com