Java @已触发PrePersist,但未触发@PostLoad

Java @已触发PrePersist,但未触发@PostLoad,java,spring-boot,spring-data-jpa,Java,Spring Boot,Spring Data Jpa,我正在尝试使用JPA EntityListeners在Spring引导应用程序中记录数据库操作 实体: @Entity @EntityListeners(DatabaseLogger.class) @Data @NoArgsConstructor @AllArgsConstructor public class ApiUser implements Serializable { private static final long serialVersionUID = -56450626

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

实体:

@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方法时,会触发DatabaseLoggeruserPrePersist方法。但是当我调用存储库的findAll方法时,DatabaseLoggeruserPostLoad方法不是。有人知道为什么调用@PrePerist方法而不调用@PostLoad方法吗?

Add spring.jpa.show-sql:true以确保对数据库进行select调用


事实上,如果findAll返回一个空集合,那么@PostLoad就不会被触发。确保您也从数据库中获取数据。

谢谢您的回答。已将show sql设置为true。执行对数据库的select调用时,肯定会检索到数据。但是不调用@PostLoad。