使用DQL仅保留最新记录

时间:2018-08-04 13:52:46

标签: doctrine-orm symfony4

我有一个带有学说的symfony应用。有一个像这样的表:

+--------+---------------------+-------+ | 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(子)查询?

1 个答案:

答案 0 :(得分:1)

我认为实体存储库中的类似内容可以为用户获取除最后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();
    }

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