如何解决删除一年多以前的记录
为此,您需要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);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。