How to JOIN without a relationship in Doctrine?(如何在没有教义关系的情况下加入?)
问题描述
我有一个实体 Log
(表 log
),其中包含成员 resourceType
和 resourceId
(带有列 resource_log
和 resource_id
).resourceType
可以例如Order
(用于订单操作,例如状态更改)或 Whatever
(用于 Whatever
相关操作).Log
和资源"实体/表之间没有任何关系(Doctrine 和数据库中都没有).
I have an entity Log
(table log
) with members resourceType
and resourceId
(with columns resource_log
and resource_id
). The resourceType
can e.g. Order
(for actions on orders, e.g. status changes ) or Whatever
(for Whatever
related actions). There is no relationships (neither in Doctrine, nor in the database) between the Log
and the "resource" entities/tables.
现在我只想选择 Log
,它们与 myOrderProperty = "someValue"
的 Order
相关.这意味着:
Now I want to select only the Log
s, that are related to Order
s with myOrderProperty = "someValue"
. That means:
SELECT
*
FROM
`log`
JOIN
`order` ON `order`.`id` = `log`.`resource_id` AND `log`.`resource_type` = 'order'
WHERE
`order`.`my_order_property` LIKE '%my_order_property_value%'
但是代码
$queryBuilder = $this->entityManager->createQueryBuilder();
$queryBuilder->select('l')->from(Log::class, 'l');
$queryBuilder->join('l.order', 'o');
...
$queryBuilder
->where('o.myOrderProperty = :myOrderProperty')
->setParameter('myOrderProperty', $myOrderProperty);
不起作用,因为实体 Log
与 Order
没有任何关系(尽管它有一个属性 order
):
doesn't work, since the entity Log
doesn't have any relationship with the Order
(though it has a property order
):
[Semantical Error] line 0, col 102 near 'o WHERE o.myOrderProperty': Error: Class MyNamespaceLog has no association named order
如何在两个实体之间没有定义关系的情况下JOIN
?
我知道,我可以使用 继承.但从语义上讲,这不是继承案例.那么有没有其他方法可以解决这个问题呢?
I know, I could use inheritance. But semantically it's not an inheritance case. So is there another way for solving the problem?
推荐答案
没有关系的JOIN
可以这样实现:
The JOIN
without relationship can be implemented like this:
$queryBuilder = $this->entityManager->createQueryBuilder();
$queryBuilder->select('l')->from(Log::class, 'l');
$queryBuilder->join(
Order::class,
'o',
DoctrineORMQueryExprJoin::WITH,
'o.id = l.resourceId'
);
...
$queryBuilder
->where('o.myOrderProperty = :myOrderProperty')
->setParameter('myOrderProperty', $myOrderProperty);
唯一的问题是,连接的实体没有添加到主实体,所以 $myLog->getOrder(...)
返回 null
.
The only problem is, that the joined entities are not added to the main entity, so that $myLog->getOrder(...)
returns null
.
这篇关于如何在没有教义关系的情况下加入?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何在没有教义关系的情况下加入?


- 正确分离 PHP 中的逻辑/样式 2021-01-01
- SoapClient 设置自定义 HTTP Header 2021-01-01
- 从 PHP 中的输入表单获取日期 2022-01-01
- 如何定位 php.ini 文件 (xampp) 2022-01-01
- PHP Count 布尔数组中真值的数量 2021-01-01
- Mod使用GET变量将子域重写为PHP 2021-01-01
- Oracle 即时客户端 DYLD_LIBRARY_PATH 错误 2022-01-01
- 没有作曲家的 PSR4 自动加载 2022-01-01
- Laravel 仓库 2022-01-01
- 带有通配符的 Laravel 验证器 2021-01-01