@PrePersist被触发,@ PostLoad没有被触发

问题描述

我正在尝试使用JPA EntityListeners在Spring Boot应用程序中记录数据库操作。

实体:

@Entity
@EntityListeners(DatabaseLogger.class)
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ApiUser implements Serializable {

    private static final long serialVersionUID = -5645062676198141323L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private long id;

    @NonNull
    @Column(unique = true)
    private String username;

    @NonNull
    private String password;

}

DatabaseLogger.class:

public class DatabaseLogger {

    @PrePersist
    public static void userPrePersist(final ApiUser user) {
        System.out.println("PrePersist triggered");
    }

    @PostLoad
    public static void userPostLoad(final ApiUser ob) {
        System.out.println("PostLoad triggered");
    }

}

当我调用相应存储库的save方法时,将触发方法DatabaseLogger#userPrePersist。但是,当我调用存储库的findAll方法时,则不是DatabaseLogger#userPostLoad方法。有谁知道为什么不使用@PostLoad方法调用@PrePerist方法

解决方法

添加spring.jpa.show-sql: true,以确保您对数据库进行了选择调用。

实际上,如果findAll()返回一个空集合,则不会触发@PostLoad。确保还从数据库中获取数据。