헤르메스 LIFE

JPA @CreatedDate Column Update시 Null 되는 현상 해결방법 본문

Spring Boot Framework

JPA @CreatedDate Column Update시 Null 되는 현상 해결방법

헤르메스의날개 2023. 3. 12. 04:42
728x90

요즘 JPA를 공부하고 있습니다. MyBatis 만 하다가, 개인적으로 공부를 진행하고 있습니다. 하다보니 막히고, 이해가 안되는 부분이 많네요. 그때마다 검색과 삽질로 해결하고 있습니다. 여기 그 삽질의 자취를 남겨봅니다.


개발환경

Spring Boot 2.7.9

H2 2.1.214

p6spy 1.8.1

slf4j 1.7.36

swagger2 2.6.1

lombok

devtools

postgresql


jpa로 개발하던 중 생성일이 초기화 되는 현상이 발생했습니다.

@Column(updatable = false)

Update 시에는 처리 되지 않는 옵션이 있었네요.


package octopus.entity;

import java.io.Serializable;
import java.time.LocalDateTime;

import javax.persistence.Column;
import javax.persistence.EntityListeners;
import javax.persistence.MappedSuperclass;

import org.springframework.data.annotation.CreatedDate;
import org.springframework.data.annotation.LastModifiedDate;
import org.springframework.data.jpa.domain.support.AuditingEntityListener;

import lombok.Getter;

/**
 * <pre>
 * 부모 클래스를 상속받는 자식 클래스에게 매핑 정보만을 제공
 * abstract 클래스로 생성해야 합니다.
 * </pre>
 */
@Getter
@MappedSuperclass // BaseEntity를 상속한 Entity들은 아래의 필드들을 컬럼으로 인식한다.
@EntityListeners(AuditingEntityListener.class) // Audting(자동으로 값 Mapping) 기능 추가
public abstract class BaseEntity implements Serializable {
    /**
     * 
     */
    private static final long serialVersionUID = 1L;
    
    /**
     * 생성자
     * 
     * @CreatedBy // implements AuditorAware<Long>를 구현한 Class를 생성해야 한다.
     */
    // private String crtId;
    @Column(updatable = false)
    protected String crtId = "admin";
    
    /**
     * 생성일자 : Entity가 생성되어 저장될 때 시간이 자동 저장된다.
     */
    @CreatedDate
    @Column(updatable = false)
    private LocalDateTime crtDt;
    
    /**
     * 수정자
     * 
     * @LastModifiedBy // implements AuditorAware<Long>를 구현한 Class를 생성해야 한다.
     */
    // private String mdfId;
    protected String mdfId = "admin";
    
    /**
     * 수정일자 : Entity가 생성되어 저장될 때 시간이 자동 저장된다.
     */
    @LastModifiedDate
    private LocalDateTime mdfDt;
    
}

출처 : https://wakestand.tistory.com/935

 

JPA @CreatedDate Column Update시 Null 되는 현상 해결방법

@CreatedDate @Column(updatable = false) private LocalDateTime created_date; JPA에서 Entity의 컬럼에 @CreatedDate 어노테이션을 사용한 경우 처음 Insert 시에는 정상적으로 현재 시간이 들어가지만 Update 시에 Null이 들어

wakestand.tistory.com

 

728x90