Doctrine2 - 双左连接查询问题
Doctrine2 - double left join query issue
我正在使用 Symfony v3.4 branch
和 Doctrine
。
我在将 SQL 查询转换为 Doctrine ORM 查询时遇到问题。
我有 3 张桌子。
- 商店
- 坚定
- 用户
用户 --> 1:1 --> 公司 --> 1:1 --> 商店
(Symfony 开发者工具栏报告表格中的关联正确)。
我想在一个查询中得到 Shop
对应于 cretain User
的数据。
我的SQL,即得到结果:
SELECT *
FROM mp2_fos_user as u
LEFT JOIN mp2_firm AS f ON u.id = f.firmUserId
LEFT JOIN mp2_shop AS s ON f.id = s.shopFirmId
WHERE u.id = 1
我的 Doctrine ORM 查询
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('u.userFirm WITH u.id = f.firmUserId', 'f')
->leftJoin('f.firmShop WITH f.id = s.shopFirmId', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
目前运行代码导致错误
[Syntax Error] line 0, col 57: Error: Expected end of string, got 'u'
我的问题的最佳做法是什么?
非常感谢您的帮助,
谢谢!
更新
尝试过:
$query = $em->createQueryBuilder()
->select('s.id')
->from('App:User', 'u')
->leftJoin('u.userFirm WITH f.firmUser = u', 'f')
->leftJoin('f.firmShop WITH s.shopFirm = f', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
得到[Syntax Error] line 0, col 54: Error: Expected end of string, got 'f'
我在想更多类似的东西(假设实体名称是正确的):
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('App:UserFirm f WITH f.firmUser = u')
->leftJoin('App:FirmShop s WITH s.shopFirm = f')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
如果您在实体中定义了映射,则无需使用 WITH
子句,当您想要使用其他匹配条件加入实体时使用 WITH
子句
class User
{
/**
* @ORM\YourRelationShipNature(targetEntity="App\Entity\Firm", mappedBy="user")
*/
private $userFirm;
}
class Firm
{
/**
* @ORM\YourRelationShipNature(targetEntity="App\Entity\Shop", mappedBy="firm")
*/
private $firmShop;
}
class Shop
{
//.....
}
然后您可以简单地使用属性来加入您的实体
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('u.userFirm', 'f')
->leftJoin('f.firmShop', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
我正在使用 Symfony v3.4 branch
和 Doctrine
。
我在将 SQL 查询转换为 Doctrine ORM 查询时遇到问题。
我有 3 张桌子。
- 商店
- 坚定
- 用户
用户 --> 1:1 --> 公司 --> 1:1 --> 商店
(Symfony 开发者工具栏报告表格中的关联正确)。
我想在一个查询中得到 Shop
对应于 cretain User
的数据。
我的SQL,即得到结果:
SELECT *
FROM mp2_fos_user as u
LEFT JOIN mp2_firm AS f ON u.id = f.firmUserId
LEFT JOIN mp2_shop AS s ON f.id = s.shopFirmId
WHERE u.id = 1
我的 Doctrine ORM 查询
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('u.userFirm WITH u.id = f.firmUserId', 'f')
->leftJoin('f.firmShop WITH f.id = s.shopFirmId', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
目前运行代码导致错误
[Syntax Error] line 0, col 57: Error: Expected end of string, got 'u'
我的问题的最佳做法是什么?
非常感谢您的帮助, 谢谢!
更新
尝试过:
$query = $em->createQueryBuilder()
->select('s.id')
->from('App:User', 'u')
->leftJoin('u.userFirm WITH f.firmUser = u', 'f')
->leftJoin('f.firmShop WITH s.shopFirm = f', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
得到[Syntax Error] line 0, col 54: Error: Expected end of string, got 'f'
我在想更多类似的东西(假设实体名称是正确的):
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('App:UserFirm f WITH f.firmUser = u')
->leftJoin('App:FirmShop s WITH s.shopFirm = f')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();
如果您在实体中定义了映射,则无需使用 WITH
子句,当您想要使用其他匹配条件加入实体时使用 WITH
子句
class User
{
/**
* @ORM\YourRelationShipNature(targetEntity="App\Entity\Firm", mappedBy="user")
*/
private $userFirm;
}
class Firm
{
/**
* @ORM\YourRelationShipNature(targetEntity="App\Entity\Shop", mappedBy="firm")
*/
private $firmShop;
}
class Shop
{
//.....
}
然后您可以简单地使用属性来加入您的实体
$query = $em->createQueryBuilder()
->select('u, f, s')
->from('App:User', 'u')
->leftJoin('u.userFirm', 'f')
->leftJoin('f.firmShop', 's')
->where('u.id = :user_id')
->setParameter('user_id', $user_id)
->getQuery();