使用Doctrine获取最近的项目功能

时间:2016-11-29 14:47:06

标签: php doctrine-orm doctrine

新学说。我正在尝试建立一个“列表最近的项目功能”。 应该获得超过3个月的所有记录,但如果结果少于50条记录则应该获取旧记录,直到获取50

因此,如果我有超过三个月的100条记录,我想要归还所有这些记录,但没有更旧的记录。如果我有过去三个月的20条记录,我希望将它们归还,以及之后最近的30条记录。

如何用Doctrine做到这一点?如果可能的话,我不想做两个查询(甚至叫它?)。

现在我的EntityRepository只获取过去三个月的所有记录,如下所示:

public function fetchRecent($from)
{
    $criteria = new Criteria();
    $criteria->where($criteria->expr()->gte('created', $from));

    return $this->matching($criteria);
}

1 个答案:

答案 0 :(得分:0)

修改

嗯,我读的有点太快,你不想限制记录,如果不超过三个月。我不知道如何通过单个查询实现这一目标。 (我会再次考虑它,但实际上却看不到......)

您可以查询数据库以了解最近有多少记录,然后查询实际结果。

public function fetchRecent($from, $nbRecords = 50)
{
    $count = $this->createQueryBuilder('c')
        ->select('COUNT(c.id)')
        ->andWhere('c.created >= :from')->setParameter('from', $from)
        ->addOrderBy('c.created', 'desc');
    $nbNewer = $count->getQuery()->getSingleScalarResult();

    $query = $this->createQueryBuilder('q');
    if ($nbNewer<$nbRecords) {
        $query->setMaxResults($nbRecords);
    } else {
        $query->andWhere('q.created >= :from')->setParameter('from', $from);
    }
    $query->addOrderBy('q.created', 'desc');

    return $query->getQuery()->getResult();
}