原则 2 - 双左联接查询问题



我正在使用Symfony v3.4 branchDoctrine

我在将SQL查询转换为Doctrine ORM查询时遇到问题。

我有3张桌子。

  • 公司
  • 用户

用户 --> 1:1 --> 公司 --> 1:1 --> 商店

(Symfony开发者工具栏报告表中的关联是正确的(。

我想在一个查询中获取与 cretainUser对应的Shop数据。

我的 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

我的教义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'

如果在实体中定义了映射,则无需使用WITH子句,当您想要使用其他匹配条件联接实体时,将使用WITH子句

class User
{
/**
* @ORMYourRelationShipNature(targetEntity="AppEntityFirm", mappedBy="user")
*/
private $userFirm;
}
class Firm
{
/**
* @ORMYourRelationShipNature(targetEntity="AppEntityShop", 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();

我在想更多类似的东西(假设实体名称是正确的(:

$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();

相关内容

  • 没有找到相关文章

最新更新