inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링부트로 직접 만들면서 배우는 대규모 시스템 설계 - 게시판

게시글 수 구현

Entity 생성 시 access 레벨 지정해주는 이유

해결된 질문

101

gui1008

작성한 질문수 2

0

강의를 듣다가 한가지 궁금한 부분이 있어서 질문남깁니다.

 

Entity 객체 생성 시

NoArgConstructor 선언 시

access를 항상 AccessLevel.PROTECTED로 설정하시는데 이유가 있으실까요?

java mysql spring-boot kafka redis

답변 2

0

쿠케

gui1008님, 안녕하세요!

 

강의에서는 생성자 외에 별도로 팩토리 메소드를 정의하여 객체 생성 로직을 캡슐화하고, 이를 활용하여 엔티티 모델을 만들고 있습니다. (팩토리 메소드에 대한 이점은 따로 학습해보시면 좋을 것 같네요!)

그런데 만약 클라이언트 코드에서 기본 생성자를 호출할 수 있으면, 불완전한 엔티티 모델이 만들어질 수 있습니다.

이러한 상황을 방지하기 위해 기본 생성자의 AccessLevel을 protected로 지정하는 것입니다.

private이 제일 안전하지만, JPA 내부적으로 리플렉션을 사용하는게 protected까지만 허용되기 때문에 이처럼 선언하는게 일반적이네요!

0

인프런 AI 인턴

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

Entity 클래스에서 @NoArgsConstructorAccessLevel.PROTECTED를 설정하는 이유에 대해 설명해드리겠습니다. 이는 주로 다음과 같은 이유로 사용됩니다:

이유 1: 객체 생성의 제약

  • 데이터베이스 제약: JPA에서는 엔티티가 프록시 객체로 생성되거나 데이터베이스에서 조회될 때 기본 생성자를 필요로 합니다. 그러나, 외부에서 객체를 임의로 생성하는 것을 막기 위해 PROTECTED로 설정하여 JPA와 같은 프레임워크에서만 객체를 생성할 수 있도록 제약을 두는 것입니다.

이유 2: 의도 명확성

  • 설계 의도: PROTECTED 수준의 접근 지정자는 클래스 내부나 서브클래스에서만 객체를 생성할 수 있게 합니다. 이는 엔티티 객체가 완전한 상태로 생성(예: 모든 필드에 값이 할당)되도록 유도하며, 잘못된 상태의 객체가 생성되는 것을 방지합니다.

이유 3: 일관성 유지

  • 코드의 일관성: 팀 내에서 코딩 표준을 유지하거나 코드의 일관성을 보장하기 위해 이러한 관행을 따를 수 있습니다. 이는 코드 리뷰 시 명확성과 가독성을 높일 수 있습니다.

이와 유사한 질문이나 더욱 구체적인 설명이 있는 게시물을 참고하실 수 있습니다:
- 엔티티 생성 및 접근 수준에 대한 이해 (유사 게시물 제목)

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

@Version 어노테이션이 붙은 필드는 낙관적 락이든 비관적 락이든 업데이트가 됩니다.

0

31

1

consumer에서 에러가 발생할 경우 데이터 유실 문의

0

47

2

게시글 테스트 데이터 삽입

0

51

2

정렬, 필터, 검색 등의 조건이 붙을 경우 최적화할 수 있는 방법이 무엇이 있을까요?

0

104

2

좋아요 기능 정합성 보장 방법

0

98

2

좋아요 동시성처리 최적의 선택?

1

136

2

프론트엔드 msa 환경 api 주소 통합? 과 서버끼리 통신 방식에대해

0

92

2

안녕하세요 무한스크롤 강의듣다가 질문이 있습니다.

0

59

1

조회수 조회 로직 질문

1

67

2

비로그인 유저도 어뷰징 방지 정책

1

72

2

CommentServiceTest의 테스트 로직 질문

0

54

2

무한 스크롤 방식에서 페이지 번호 방식 쿼리의 문제점 의문

1

74

2

path 쿼리 관련 질문드립니다!

0

60

2

antigravity 에디터를 쓰신다면 종료해주세요

1

123

0

프로젝트 구조

0

88

2

article_like_count api test

0

79

2

이벤트 페이로드 객체의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!.

0

104

2

[33. 좋아요 수 구현] 에서 테스트 하는 화면 동시성 문제

0

91

2

findByPath에서 articleId로도 검색을 해야 할 것 같아요.

0

92

3

jpa ddl-auto none을 하는 이유와 join 방법

0

97

2

팩터리 메소드와 response 객체 사용 이유가 궁금합니다!

0

90

2

커서 기반 페이지네이션 과 무한 스크롤링

0

110

2

게시글 생성 로직에서 오류 발생시 redis 게시글 수 되돌리기

0

97

2

멀티 모듈이 아닌 MSA 환경에서 common

0

156

2