繁体   English   中英

在查询中使用别名的查询生成器

[英]Query builder using alias name inside a query

是否有可能这样查询构建:

    $qb = $this->em->createQueryBuilder();

    $qb->select(
        'af.shortKey as wg, 
        af.id as afId', 
        'afl.name as afName', 
        'l.id as langId') // -> this one
        ->from('DatabaseBundle:ArticleFamily', 'af')
        ->leftJoin('af.articleFamilyLanguages', 'afl')
        ->leftJoin('afl.language', 'l')
        ->where('langId = :languageId') //-> this is causing the problem
        //if i use it like l.id = :languageId is working. But I don't want it like this.
        ->setParameter('languageId', $params['lang']);

我需要这样使用它,因为我在url中传递了一些参数,而我不能使用l.id

如果我使用此查询,则会收到以下错误:

执行'SELECT a0_.short_key AS short_key0,a0_.id AS id1,a1_.name AS name2,l2_.id AS id3时发生异常来自article_family a0_ LEFT JOIN article_family_language a1_ ON a0_.id = a1_.article_family_id LEFT JOIN语言l2 a1_.language_id = l2_.id,其中id3 =吗? 带有参数[“ 3”]的ORDER BY name2 ASC LIMIT 10 OFFSET 0':

SQLSTATE [42S22]:找不到列:1054“ where子句”中的未知列“ id3”

id3应该实际上是l2_.id

您不能在WHERE子句中使用字段别名。 相反,您可以尝试使用HAVING

相关的SO问题/答案: 可以在mysql的WHERE子句中使用别名吗?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM