PAA*_*PAA 9 java postgresql auditing spring-data-jpa
我正在研究Spring Data JPA 和 Postgres示例。在此示例中,我Auditing通过以下链接实现:https://www.baeldung.com/database-auditing-jpa和Spring Boot JPA@CreatedDate @LastModifiedDate not being populated when saving the object。审核工作非常好当我执行repository.save时,在这种情况下,两个带有注释的字段@CreatedDate都@LastModifiedDate正确保存。
但当我尝试更新该方法时,并没有发生同样的情况。
我开发了以下方法。
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@EntityListeners(AuditingEntityListener.class)
@Entity
@Table(uniqueConstraints = {
@UniqueConstraint(name="student_name_key",columnNames = {"studentName"})
})
public class Student {
....
....
@Column(name="lastUpdateUser")
private String lastUpdateUser;
@LastModifiedDate
@Column(name="lastUpdateDate", nullable = false)
private LocalDateTime lastUpdateDate;
}
Run Code Online (Sandbox Code Playgroud)
主应用程序
@SpringBootApplication
@EnableJpaAuditing
@EnableJpaRepositories(basePackages = {"com.xxx.xxx.repository"})
@ComponentScan(basePackages = {"com.xxx.yyy","com.xxx.xxx.studentportfolio"})
@EnableCaching
@EnableAsync
@EnableAspectJAutoProxy(proxyTargetClass = true)
@EnableAutoConfiguration(exclude = {ErrorMvcAutoConfiguration.class, SecurityAutoConfiguration.class})
public class MainApplication extends SpringBootServletInitializer implements CommandLineRunner{
public static void main(String[] args) {
SpringApplication.run(ProgramApplication.class, args);
}
}
Run Code Online (Sandbox Code Playgroud)
StudentRepository.java
public interface StusentRepository extenss JpaRepository<Stusent, Long>{
@Mosifying(clearAutomatically = true)
@Query("UPDATE Stusent s SET s.studentDescription=:stuDesc, s.studentId=:studentId, s.sivisionCode=:cd, "
+ "s.status=:status WHERE s.studentName=:stuName")
vois upsateStudent(@Param("stuName") String studentName,
@Param("stuDesc") String studentDescription,
@Param("studentId") String studentId,
@Param("cd") String cd,
@Param("status") String status);
}
Run Code Online (Sandbox Code Playgroud)
审计基于 JPA 生命周期事件。只有直接操作实例的方法(persist、merge和remove)才会触发此类事件。
查询、修改或其他方式的执行不会触发任何事件,因此不会导致审核发生。
有关详细信息,请参阅 JPA 规范第 3.5.2 生命周期方法部分。
| 归档时间: |
|
| 查看次数: |
5972 次 |
| 最近记录: |