inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

JPA의 DB조회에 대해서 질문드립니다.

226

octo J

작성한 질문수 1

0

안녕하세요.

스프링JPA로 블로그 게시판을 만들고 있습니다.

복잡한 기능 말고 게시판만 하나 만들어 보고 심층공부를 들어갈려고 하는중입니다.

--------------------------------------------------------------------------------------------------------------------

일단 DB는 이렇게 구성돼 있고  BLOGLIST로 게시판 목록을 관리하기 위해  BLOG_NUM에 외래키를 주고 테이블을 따로 만들어서 조인했습니다.

 

--------------------------------------------------------------------------------------------------------------------

그리고 엔티티를 각각 만들고 다대일 연결까지 성공해서 데이터 조회까지 됩니다.

@Entity(name = "BLOG")
@Getter @Setter @ToString
@RequiredArgsConstructor
public class Blog {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name="CON_NUM")
    private Integer con_num;

    @ManyToOne
    @JoinColumn(name = "BLOG_NUM", referencedColumnName = "BLOG_NUM")  //referencedColumnName = "BLOG_NUM"~~ 은 어떤 컬럼과 연결이 됐는지 지정.
    private BlogList blogObj;

    @Column(name="CON_TITLE")
    private String title;

    @Column(name="CON_CONTENT")
    private String content;

    @Column(name ="CON_WRITEDATE")
    private Date writeDate;

}

 

@Entity(name = "BLOGLIST")
@Getter @Setter @ToString
@RequiredArgsConstructor
public class BlogList {


    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "BLOG_NUM")
    private Integer blogNum;

    @Column(name = "BLOG_NAME")
    private String blogName;

}

----------------------------------------------------------------------------------------------------------------------

이런식으로 BLOGLIST테이블의 항목까지 출력을 할 수 있었습니다.

여기서부터 문제입니다.

SELECT * FROM BLOG WHERE=BLOG_NUM=?

이러한 쿼리를 실행시켜서 블로그의 메뉴에서 각각의 항목을 눌렀을 때 각각의 내용을 출력하려고 합니다.

------------------------------------------------------------

그래서 제가 시도한것은

1. 레파지토리에서 아래 주석된 메소드로 조회메소드를 만들고 

public interface BlogRepository extends JpaRepository<Blog, Integer>{
    List<Blog> findByTitleContaining(String searchWord);
    //List<Blog> findByBlogObj(Integer blogNum);
}

컨트롤러에서 이런식으로 조회를 시도 해보았으나 잘 되지 않았습니다.

    // 게시판별 리스트
@GetMapping("/contest")
public String testList(Integer blogNum, Model model){
        model.addAttribute("list", blogRepository.findByBlogObj(blogNum));
        return "/layouts/conList";
    }

----------------------------------------------------------

그래서 2번으로 시도한 것이 리파지토리에 쿼리 직접 넣는 것이었습니다.

@Query(value = "SELECT * FROM BLOG B WHERE B.BLOG_NUM = ?", nativeQuery = true) //true SQL, false JPQL
List<Blog> findAllByBlogNum(Integer BlogNum);
@GetMapping("test")
public String findBlog(Integer BlogNum, Model model){
System.out.println("파람:" + BlogNum);
List<Blog> blog = blogRepository.findByBlogObj(BlogNum);
model.addAttribute(blog);
return "/layouts/conList";
}

이 방식은 이렇게 파라미터를 보냈으나 Null값이 뜨고 파라미터를 가져오지 못하네요.

-------------------------------

아무래도 엔티티 설계에 제가 이해가 부족해서 그런것 같은데

엔티티에 어느 부분을 손을 보아야 제가 원하는 조회를 할수 있을까요?

jpa

답변 0

안녕하세요 치킨 디도스 이벤트 보고 흉내내보려 들어왔습니다..

0

26

2

join에대해 질문드립니다.

0

22

1

코드 질문

0

30

2

To-Do App

0

27

1

twitterdb 연결이 안돼요

1

30

2

@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.

0

33

2

changeTeam 메서드 질문

0

35

1

테스트 관련 질문!

0

57

2

안녕하세요 질문있습니다.

0

49

2

application.properties가 적용되지 않아요

1

76

3

새 프로젝트 속 제너레이터에 SpringBoot가 없습니다.

0

55

2

설정 정보 없이 임베디드 데이터베이스 생성

0

41

1

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

42

1

N+1 관련해서 질문있습니다.

0

97

3

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

57

2

inheritance startegy 선택시 고려사항

0

41

1

Entity 동등성 비교

0

47

1

패키지 구분에 대해 궁금한게 있습니다

0

51

2

스프링부트 서버 에러나요

0

37

1

RepositoryTest의 패키지 위치가 domain인 이유

0

60

2

도메인 모델에서 관계와 규칙을 구분하는 방법

0

88

2

16 강의 메세지 retryCount의 의도

0

46

2

JPA Repository 질문이 있습니다!

1

58

2

페이지네이션 처리를 쿼리에서 하는 방식 질문

1

50

1