• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

BaseEntity 가 있음에도 불구하고 registeredDateTime 을 사용하는 이유가 무엇일까요?

23.11.23 14:35 작성 조회수 186

0

안녕하세요.

덕분에 좋은 강의 정말 잘 듣고 있습니다.
강의를 수강하던 도중에 궁금한 부분이 생겨 이렇게 질문을 남깁니다.

BaseEntity(@CreateDate) 로 인해서 객체가 생성되는 시점을 알 수 있음에도 불구하고 registeredDateTime 이라는 필드값을 정의한 이유가 궁금합니다.

테스트코드를 통해 한층 더 검증하기 쉽게 하려는 용도로 사용하시는 걸까요?

감사합니다

답변 2

·

답변을 작성해보세요.

1

안녕하세요, leeseongju 님! :)

이전 질문 중에 같은 질문이 있어 링크로 대신 답변드립니다.
https://www.inflearn.com/questions/913896/lesson5-5-order-entity%EC%9D%98-registereddatetime-%EC%BB%AC%EB%9F%BC

 

감사합니다. :)

leeseongju님의 프로필

leeseongju

질문자

2023.11.27

친절한 답변 너무 감사드립니다.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.11.25

안녕하세요, 인프런 AI 인턴입니다.

@CreateDate로 표시된 BaseEntity의 생성 시점 추적 기능은 실제 엔티티가 데이터베이스에 처음 저장될 때 해당 시간을 자동으로 기록합니다. 이는 스프링 데이터 JPA의 감사 기능 중 하나이며, 개발자가 직접 날짜와 시간을 관리하지 않아도 되므로 매우 유용합니다.

registeredDateTime과 같은 별도의 필드 값을 정의하는 이유는 몇 가지가 있을 수 있습니다:

  1. 명시적인 이름 사용: @CreateDate는 자동으로 엔티티의 생성 시점을 표시하는 기능을 담당하지만, 엔티티의 문맥에 따라 registeredDateTime과 같이 그 용도가 더 분명하게 드러나는 이름을 사용할 수 있습니다.

  2. 추가적인 제어: 특정 조건에서 생성 시간을 다르게 적용하거나, 생성 시점 말고도 다른 시점에 대한 기록이 필요할 때, 추가적인 필드를 정의함으로써 더 세밀한 제어가 가능합니다.

  3. 테스트 용이성: 말씀하신 것처럼 테스트 코드에서 시간 관련 로직을 테스트할 때, registeredDateTime과 같은 필드를 직접 조작하여 다양한 시나리오를 쉽게 재현할 수 있습니다.

이렇게 별도로 시간 관련 필드를 추가하는 것은 엔티티의 요구 사항, 비즈니스 로직의 특성, 그리고 테스트의 용이성에 따라 결정됩니다.

도움이 되었으면 좋겠습니다, leeseongju님. 추가적인 궁금증이 있으시면 언제든 질문해주세요. 감사합니다.