首页 > 解决方案 > 使用 Doctrine 的顺序连接表

问题描述

我用学说写了一个查询,我在其中加入了水果和维生素表。

我已经按名称 ASC 对维生素进行了分类,但我需要对连接表做同样的事情。

我试过了

addOrderBy()

,但没有运气..

注:“c”是维生素表。

一切都按原样退回,除了水果无序退回。

我的代码:

 $queryBuilder =  $this->createQueryBuilder('c')
        ->select('c', 'ct.name AS fruitName', 'ct.id AS fruitId')
        ->join('App\Entity\Fruits', 'ct', Expr\Join::WITH, 'ct.id = c.fruitName')
        ->orderBy('c.name');

    $fruits = $queryBuilder->getQuery()->getResult();
    $structure = [];
    foreach ($fruits as $fruit) {
        $structure[$fruit['fruitName']][] = $fruit[0];
    }
    return $structure;

标签: phpmysqlsymfonydoctrine-ormdoctrine

解决方案


尝试其中之一:

选项1:

$qb->orderBy('c.name ASC, ct.name ASC');

选项 2:

$qb->addOrderBy('c.name', 'ASC')
   ->addOrderBy('ct.name', 'ASC')

推荐阅读