Delete Datensätze von vor mehr als 1 Jahr
Ich speichere Twitter-Tweets in meiner Datenbank mit Spring JPA Repositories. Das Datum des Tweets wird als Datum / Uhrzeit in der MySQL-Datenbank gespeichert. Jetzt möchte ich alle Tweets löschen, die älter als ein Jahr sind. Ich habe gesehen, da ist die FunktionCURRENT_TIME
und ich dachte an so etwas wieCURRENT_TIME - 360
. Ich weiß, dass das nicht die richtige Syntax ist, aber ich habe keine Ahnung, wie das geht. Folgendes habe ich:
@Modifying
@Transactional
@Query("DELETE FROM Tweetpost t WHERE t.createdAt > ")
int removeOlderThan();
EDIT SOLVED:
Repository
@Modifying
@Transactional
@Query("DELETE FROM Tweetpost m WHERE m.createdAt < :date")
int removeOlderThan(@Param("date") java.sql.Date date);
Bedienung
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);
}