[Spring Boot] JPA Auditing 으로 생성/변경일시 관리하기
안녕하세요. 남산돈가스입니다. 오늘은 Spring Boot + JPA 환경에서 Auditing을 이용하여 생성/변경일시를 관리하는 법에 대해 포스팅하겠습니다. 일반적으로 테이블을 설계할 때, 거의 필수적으로 관리되는 컬럼들이 있습니다. 대표적인 예로 생성일시, 변경일시 등이 있을 것이고, 또 최종 변경자, 최초 생성자도 있을 수 있겠네요. JPA환경에서 Entity들을 관리할 때, 이 모든 Entity에서 위에서 언급한 컬럼들을 일일이 관리하기엔 번거로움이 있을 것 같습니다. 또한, 코드 레벨에서 이 데이터들의 값을 관리하기는 더 어려운 일이 아닐 수 없겠죠. 이런 불편함들을 해소하고자(?) 혹은 Spring Data JPA가 아닌 다른 프레임워크 환경에서의 ORM에서 기본적으로 제공되던 것(ex. Sequelize 등) 들을 대체해 줄 수 있는 것이 바로 Spring Data JPA의 Auditing 입니다. Auditing을 사용하기 위해서는 간단한 설정이 필요합니다. Auditing을 활성화하기 위한 적당한 이름의 Config 파일을 생성한 뒤, @EnableJpaAuditing 어노테이션을 추가합니다. @EnableJpaAuditing @Configuration public class JpaAuditingConfig { } Config를 생성한 뒤, 이제 Audity로 제공할 데이터들을 정의하는 클래스를 생성합니다. @Getter @MappedSuperclass @EntityListeners (AuditingEntityListener.class) public abstract class Audity { @CreatedDate @Column (name = "created_date" , updatable = false) private LocalDateTime createdDate; @LastModifiedDate @Column (name = "updat...