inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 데이터 JPA

모든 쿼리에 같은 where조건이 필요 할 때

326

hkkim

작성한 질문수 1

0

예시 상황은 여러 학생이 테이블을 공유해서 사용하여 모든 테이블에 student_id 컬럼이 있고 이를 이용해 데이터 사용자를 구별한다고 했을 때입니다.

이럴 때 모든 find, update, delete 절에 where student_id = '1000' 와 같은 조건이 필요하다고 하면 단순히 모든 find문에 findByStudentId 하고 아이디를 넣어주는 수밖에 없을까요?

어플리케이션 사용자 학생 아이디는 properties에 적어놓고 가져와 사용할 것이라 프로세스 실행중에 파라미터로 받아오는 경우는 없습니다.

 

java spring spring-boot jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴이에요.
해당 상황에서는 모든 쿼리에 동일한 where 조건이 필요할 경우, 다음과 같은 방법을 고려해 볼 수 있을 것 같습니다.

  1. Custom Repository 사용: JPA나 Spring Data의 Repository를 직접 구현하여 공통 where 조건을 적용하는 메서드를 만들 수 있습니다. 예를 들어, StudentRepository를 상속한 CustomStudentRepository를 만들어서 findByStudentId를 호출해도 항상 where student_id = ‘1000’이 적용되도록 구현할 수 있습니다.

  2. AOP (Aspect Oriented Programming) 적용: AOP를 활용하여 쿼리 실행 전에 항상 공통으로 where 조건을 적용하는 공통 로직을 구현할 수 있습니다. 이렇게 하면 개별 쿼리 메서드를 호출할 때마다 where student_id = ‘1000’을 추가하지 않아도 될 것입니다.

  3. 상속을 통한 공통 로직 적용: JPA의 엔티티 상속을 활용하여 부모 클래스에 공통 where 조건을 적용하는 로직을 구현할 수 있습니다. 이렇게 하면 상속받는 모든 자식 클래스에서 자동으로 해당 where 조건이 적용될 것입니다.

위의 방법 중 어느 하나를 선택하여 사용하면 단순히 모든 find문에 findByStudentId와 같은 메서드를 호출하는 것보다 효과적인 코드를 작성할 수 있을 것입니다. 감사합니다.

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

70

1

existsByUserIdAndProjectId vs existsByUserAndProject 중 어떤 방식이 적절할까요?

0

107

3

MemberRepository 구현체

0

58

1

pdf 표현 질문드립니다.

0

62

1

로그가 남지 않는 문제.

0

81

1

테스트 라이브러리가 강의는 junit4가 맞나요??

0

70

2

pdf 파일과 차이점이 있는 것같은데 문제 없나요?

0

72

2

@PrePersist, @PreUpdate 호출 시점 질문드립니다.

0

91

2

Sort 인터페이스는 잘 사용 안하나요?

0

52

1

스캔대상 질문드립니다.

0

46

1

하이버네이트6에서의 최적화에 이은 질문

0

85

1

save() vs saveAndFlush DB 통신 횟수

0

54

1

순수 JPA 리포지토리 코드 수정부분

0

86

2

bulk연산 후 flush하는 이유를 모르겠어요

0

152

3

bulk insert 질문입니다.

0

178

2

교만했던 것 같아요.

0

147

1

RESTful 강의는 안하시는 건지 궁금합니다.

0

147

2

동적 테이블에 대한 질문

0

86

1

영속성 전이와 연관관계

0

130

2

강의 10:25 질문

0

74

1

단건 update 질문

0

95

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

119

1

Projection 개념과 데이터 전달과정에 대해 질문 있습니다.

0

136

1