inflearn logo
강의

Course

Instructor

Practical! Spring Data JPA

Specifications

Specification 을 활용하는 RSQL 파서 + Querydsl 의 조합은 어떻게 생각하실지 궁금합니다.

Resolved

777

Truestar

68 asked

0

안녕하세요 이제 추워지는데 건강조심하셔요!
뭔가 떠오르는게 있을때 강사님의 의견이 가장 궁금한것 같아 또 남기게 되었습니다

RESTful API 구현방식 에서, 서버측에 검색조건에 대한 쿼리로직는 최소화 하도록, 그리고, Client 에서 검색조건 을 제공하도록 조건절이 문법화 된 RSQL 이란것을 알게되었는데요...

이 RSQL 을 파싱하는 rsql-parser 를 통해 Querydsl 의 BooleanExpression 로 변환해주는  기능에 Spring-boot Starter 의존성으로 제공해주는 라이브러리를 하나 발견했습니다.

perplexhub/rsql-jpa-specification: Java Library to Translate RSQL into Spring Data JPA Specification and QueryDSL Predicate (github.com)

(링크 아래쪽에 Querydsl 설명이 있어요)

저의 눈엔 꿀이 가득한 꿀통을 찾은 느낌같은 느낌인데요.. 서브프로젝트로 진행보려 생각중인데, 실무에서 꺼려지는 기술은, 좋아보여도 따라가다 하얗게 타버리는 하루살이가 될 수 있기때문에..
적용하려는 폼만 잡고있습니다^^;

슬쩍 보셨을때 어떤 기분이 드시는지 강사님의 견해가 궁금합니다
(JPA Specification 이나 저놈이나 그놈이 그놈일까요?..ㅎㅎ)

읽어주셔서 감사해요

rsql spring-boot spring java JPA

Answer 1

1

yh

안녕하세요. Truestar님

재미있는 기능이네요^^

서브 프로젝트에서 사용해보시고 판단해보시면 좋을 것 같아요.

사용량이 적어서 조금 걱정되기는 하네요.

실무에서는 복잡한 fetch 조인, 여러 엔티티를 조인하고 원하는 필드만 DTO로 조회하기, 조인이 많이 들어간 상태에서 정렬등을 수용할 수 있어야 하는데, 이런 부분까지 함께 고려해보시면 좋을 것 같아요.

감사합니다.

0

Truestar

조언 감사드려요^^ 시도해보겠습니다.

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

0

75

1

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

0

108

3

MemberRepository 구현체

0

58

1

pdf 표현 질문드립니다.

0

63

1

로그가 남지 않는 문제.

0

83

1

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

0

72

2

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

0

73

2

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

0

93

2

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

0

52

1

스캔대상 질문드립니다.

0

46

1

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

0

86

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

148

2

동적 테이블에 대한 질문

0

86

1

영속성 전이와 연관관계

0

131

2

강의 10:25 질문

0

74

1

단건 update 질문

0

97

2

엔티티 와 도메인의 경계

0

127

1

UsernameOnlyDto 타입 type mismatch 오류

0

121

1

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

0

136

1