删除 1 年以上的记录
我正在使用春季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);
}