java - 删除 1 年多以前的记录

标签 java mysql spring jpa

我正在使用 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);


    }

最佳答案

为此,您需要 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);
     }

关于java - 删除 1 年多以前的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35550019/

相关文章:

java - Android 应用程序无法启动 Activity 组件信息

php - Mysql MySQL 或 PHP 将行动态转换为两列

mysql - PHP/MySQL 数据库每日重置

如果值不存在,则 Mysql 更新

java - 如何使用 mysql 数据库中的存储过程在数据库中插入图像 url?

java - 从 Map 中删除实体尝试将引用清空

java - 如果从 Overlay 开始,如何从 Activity 中获取结果?

java - 管理 quartz 作业、删除

java - mybitis运行更新sql错误

java - 在 Spring MVC 中,我有一个 @ModelAttribute 并且它抛出异常。如果我收到此异常,我想显示一个页面。如何?