使用 DQL 只保留最新的记录

Keep only newest records using DQL

我有一个带有教义的 symfony 应用程序。有一个table喜欢:

+--------+---------------------+-------+ | user | log_date | foo | +---------+---------------------+-------+ | john | 2018-03-20 22:59:18 | 58 | | kyle | 2018-04-11 13:45:02 | 22 | | paul | 2018-11-08 22:19:16 | 41 | | kyle | 2018-08-14 09:39:26 | 19 | | fred | 2018-03-28 06:08:31 | 24 | | john | 2018-01-21 11:52:17 | 81 | | ... | ... | ... | +---------+---------------------+-------+

cron 应该执行 symfony 命令来删除所有记录,但保留每个用户的最新 10 条记录。这可以使用 DQL 完成还是我必须使用 SQL(子)查询?

我认为实体存储库中类似这样的东西可以获取除最后 10 个用户之外的所有条目

public function getAllExceptLatest($user)
{
    return $this
        ->createQueryBuilder('t')
        ->andWhere('t.logDate <= :logDate')
        ->orderBy('t.logDate', 'DESC')
        ->setParameter(':logDate', $this->getLatestDate($user))
        ->setFirstResult(10)
        ->getQuery()
        ->execute();
}

public function getLatestDate($user)
{
    return $this->createQueryBuilder('e')
        ->select('MAX(e.logDate)')
        ->andWhere('e.user = :user')
        ->setParameter(':user', $user)
        ->getQuery()
        ->getSingleScalarResult();
}

在控制器中你可以使用

   public function keepLatest(){
        $em = $this->getDoctrine()->getManager();
        $userRepo = $em->getRepository(User::class);

        $users = $userRepo->findAll();
        foreach ($users as $u) {
            $records = $userRepo->getAllExceptLatest($u);
            foreach ($records as $r)
            $em->remove($r);
        }
        $em->flush();
    }

我没有对此进行测试,但在我的应用程序中,类似的方法工作正常