删除一年多以前的记录

问题描述

为此,您需要2个步骤。首先,您需要一个方法,该方法将要删除消息的日期作为参数,并且@Query根本不需要注释。

所以在您的存储库中,您必须有类似

    @Modifying
    public void deleteByCreatedAtBefore(Date expiryDate);

现在,在您的服务方法中,您将计算日期并将其像这样传递

    public void performTweetCleanup(){
       //calculate date
       Calendar cal = Calendar.getInstance();
       Date today = cal.getTime();
       cal.add(Calendar.YEAR, -1);
       Date prevIoUsYear = cal.getTime();

       //call the method
       MyTweeterRepository.deleteByCreatedAtBefore(prevIoUsYear);
     }

解决方法

我正在使用Spring
JPA存储库将Twitter推文保存在数据库中。鸣叫的日期在MySQL数据库中另存为Datetime。现在,我想删除所有超过一年的推文。我看到有功能CURRENT_TIME,想到了类似的东西CURRENT_TIME - 360。我知道那不是正确的语法,但是我不知道该怎么做。这是我所拥有的:

@Modifying
@Transactional
@Query("DELETE FROM Tweetpost t WHERE t.createdAt > ")
int removeOlderThan();

编辑已解决:

仓库:

@Modifying
    @Transactional
    @Query("DELETE FROM Tweetpost m WHERE m.createdAt < :date")
    int removeOlderThan(@Param("date") java.sql.Date date);

服务:

public void removeOldItems() {
        Calendar cal = Calendar.getInstance();
        cal.add(Calendar.DATE,-360);

        java.sql.Date oneYear = new java.sql.Date(cal.getTimeInMillis());

        tweetRepository.removeOlderThan(oneYear);


    }