inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 데이터 JPA

JPA에서 테이블명을 변수값으로 받아와서 select하는 경우

652

esther

작성한 질문수 3

0

안녕하세요.

강의를 보면서 이런저런 기능을 구현해보고 있는데요.

혹시 API에서 "/api/{TABLE_NAME}"으로 get 을 보내

받아온 TABLE_NAME과 일치하는 테이블을 찾아 해당 테이블의 값을 모두 findAll 하게 할 수 있나요?

복수의 테이블에 대하여 각각 findAll을 하고자 할때 테이블별로 API를 만드는 방법밖에 없는지 궁금합니다.

테이블마다 구조는 각각 다릅니다.

따라서 테이블마다 entity와 repository는 만들어줄 수밖에 없을 것같은데

{TABLE_NAME}을 해당하는 entity와 repository를 찾도록 분기문을 하는게 최선일까요?

네이티브 쿼리도 생각해 봤는데 가능하면 쿼리 사용안하고 해보고 싶은데 검색해봐도 잘 모르겠네요.

조언 부탁드립니다.

감사합니다.

jpa spring java JPA

답변 1

0

나무늘보

말씀해 주신에 방식은 아래와 같은 방식으로 강제로 만들 순 있을것 같습니다.

컨트롤러에서 미리 제공가능한 서비스 리스트를 '맵'같은 콜렉션으로 들고 있으면  더 간단하게도 구현은 가능하겠습니다.

하지만 이런 코드는...실무에서는 쓰지 마시고, 개인 프로젝트에서만 사용하시길 추천드립니다.

어쩃든, 질문의 요점은 스트링으로 클래스를 생성하는 방법같은데, 가능합니다.

// 파일명: MemberController.java 
// 아래의 두 서비스 클래스가 존재한다고 가정. 두 서비슨느 모두 findAll() 메서드를 가지고 있다고 가정.
// hello.jpashop.service.MemberService 
// hello.jpashop.service.AnotherService 

@GetMapping("/hello/{className}")
    public String something(@PathVariable String className) throws Exception {

        String prefix = "hello.jpashop.service.";
        String suffix = "Service";
        className = prefix + className + suffix;

        Class c = Class.forName(className);
        Object o = c.getConstructor().newInstance();
        if (o instanceof MemberService) {
            MemberService ms = (MemberService) o;
            ms.findAll();
        } else if (o instanceof AnotherService) {
            AnotherService as = (AnotherService) o;
            as.findAll();
        }

        return "hello";
    }

spring boot 2.7.13-SNAPSHOT trace 소문자 로그 안나옴

0

532

1

<스프링 데이터 Common: 기본 리포지토리 커스터마이징> 에 대한 질문

0

392

1

comment table에서 저장될떄 왜 id값이 2부터저장이되는건가요?

0

406

1

@EnableJpaRepositories 설정을 스프링부트가 어디에서 자동설정하나요?

0

449

0

PersistenceContext 관련 질문드립니다.

0

334

1

지금(Eager), 나중에(Lazy)의 의미를 모르겠습니다

0

338

1

transaction 구간이 길어질 경우의 처리방법 문의드립니다.

0

905

1

docker postgres

0

291

1

Multiple DataSource 사용 시 transaction 관련 질문 드립니다.

0

2907

1

entity 중 null이 아닌 필드만 update 할 방법이 있을까요?

0

1190

1

Eager 모드일 경우, join을 inner join으로 바꾸는 법이 있을까요?

0

385

1

엔티티를 상속받는 DTO가 일반적인가요?

1

1847

1

커스텀 타입 클래스를 String 타입 처럼 이용해 쿼리하는 방법에 대해 질문하고 싶습니다.

0

339

1

연관관계 매핑 어떤식으로 해야될지 감이 안잡힙니다.

0

566

4

EntityManager 주입시 Annotation관련 질문드립니다.

0

565

1

클래스 기반 프로젝션 사용 관련 질문

0

560

1

save 메서드 질문드립니다.

0

258

1

복잡한 통계쿼리도 JPA로 가능한가요?

2

5592

1

find 와 get의 차이가 무엇인가요?

0

890

1

실무에서 JPA 할 때 FK로 개발할때 연관관계를 꼭 맺어주어야 하나요?

0

998

1

\dt Did not find any relations.

0

477

1

소스코드는 어디서 볼 수 있을까요?

1

282

1

table 생성과 select 문에 대한 질문

0

169

1

스프링 데이터 RepositoryTest 관련 질문

0

2168

2