我使用Spring JPA存儲庫在我的數據庫中保存了Twitter推文。推文的日期被保存爲MySQL數據庫中的日期時間。現在我想刪除所有超過一年的推文。我看到有功能CURRENT_TIME
,我想到了像CURRENT_TIME - 360
。我知道這不是正確的語法,但我不知道如何做到這一點。這裏是我有:刪除超過1年前的記錄
@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);
}
'WHEREt.createdAt
Strawberry
不適JPQL。 – julien
那麼爲什麼這個標記爲mysql? – Strawberry