我正在使用 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);
}
最佳答案
为此,您需要 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);
}
关于java - 删除 1 年多以前的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35550019/