Doctrine 2: group by field alias (Error: '…' does not point to a Class. )

前端 未结 3 925
无人及你
无人及你 2021-01-23 06:20

I got this Doctrine query:

        select upper(substring(e.name, 1, 1)) first_letter
        from Application\\Models\\Exercise e
        group by first_letter
         


        
相关标签:
3条回答
  • 2021-01-23 06:59

    I know you've answered this question yourself but just wondering if you tried using DISTINCT:

    select DISTINCT upper(substring(e.name, 1, 1)) first_letter
    from Application\Models\Exercise e    
    order by e.name asc
    

    Ordering by e.name is equivalent to first_letter in this case.

    0 讨论(0)
  • 2021-01-23 07:00

    It seems like there is no good way to do this via DQL (at least none I could find), as Doctrine always tries to map the result to an entity. I ended up doing a native query using the PDO connection. Here is the code I use in my repository:

        return $this->getEntityManager()->getConnection()->executeQuery('
            select upper(left(tl_exercise.name, 1)) as first_letter
            from tl_exercise
            group by first_letter
            order by first_letter asc
        ')->fetchAll(\PDO::FETCH_COLUMN);
    

    At least I got rid of the sorting/grouping in my client code. And I can use the LEFT() function which is not available in DQL by default (you can use SUBSTRING() however).


    UPDATE: There is a way to get this done using EntityManager::createQuery and DQL, see rojoca´s answer

    0 讨论(0)
  • 2021-01-23 07:09

    My guess is that it is looking for first_letter to be an Entity. This is similar problem in some sql queries where you can't use a computed attribute from the select statement as criteria. Try the following:

    select upper(substring(e.name, 1, 1)) first_letter
    from Application\Models\Exercise e
    group by upper(substring(e.name, 1, 1))
    order by upper(substring(e.name, 1, 1)) asc
    
    0 讨论(0)
提交回复
热议问题