jul*_*ien 7 java mysql spring jpa
我正在使用spring JPA Repositories在我的数据库中保存Twitter推文.推文的日期在MySQL数据库中保存为日期时间.现在我要删除所有超过一年的推文.我看到有功能CURRENT_TIME,我想到了类似的东西CURRENT_TIME - 360.我知道这不是正确的语法,但我不知道如何做到这一点.这是我有的:
@Modifying
@Transactional
@Query("DELETE FROM Tweetpost t WHERE t.createdAt > ")
int removeOlderThan();
Run Code Online (Sandbox Code Playgroud)
编辑解决:
库:
@Modifying
@Transactional
@Query("DELETE FROM Tweetpost m WHERE m.createdAt < :date")
int removeOlderThan(@Param("date") java.sql.Date date);
Run Code Online (Sandbox Code Playgroud)
服务:
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);
}
Run Code Online (Sandbox Code Playgroud)
为此,您需要两个步骤.首先,您需要一个方法,将您要删除消息的日期作为参数,您@Query根本不需要注释.
所以在你的存储库中你必须有类似的东西
@Modifying
public void deleteByCreatedAtBefore(Date expiryDate);
Run Code Online (Sandbox Code Playgroud)
现在在您的服务方法中,您将计算日期并像这样传递它
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);
}
Run Code Online (Sandbox Code Playgroud)
解决了:
存储库:
@Modifying
@Transactional
@Query("DELETE FROM Tweetpost m WHERE m.createdAt < :date")
int removeOlderThan(@Param("date") java.sql.Date date);
Run Code Online (Sandbox Code Playgroud)
服务:
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);
}
Run Code Online (Sandbox Code Playgroud)