删除1年多以前的记录

我正在使用spring JPA Repositories在我的数据库中保存Twitter推文。 推文的日期在MySQL数据库中保存为日期时间。 现在我要删除所有超过一年的推文。 我看到有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); } 

为此,您需要两个步骤。 首先,你需要一个方法,将你想要删除消息的日期作为参数,你@Query不需要@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); } 

解决了:

库:

 @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); } 

在Java中计算当前时间减去一年,然后使用以下查询:

 DELETE FROM Tweetpost t WHERE t.createdAt < :nowMinusOneYear 

如果你想要你可以使用的当前时间

 System.getCurrentTimeMillis() 

从旧日期开始计算时间并从当前日期中减去时间,然后您只需将其与一年的持续时间进行比较即可。 也许你应该为闰年添加一些东西。