新学说。我正在尝试建立一个“列表最近的项目功能”。 应该获得超过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);
}
答案 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();
}