JPA의 DB조회에 대해서 질문드립니다.
226
작성한 질문수 1
안녕하세요.
스프링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값이 뜨고 파라미터를 가져오지 못하네요.
-------------------------------
아무래도 엔티티 설계에 제가 이해가 부족해서 그런것 같은데
엔티티에 어느 부분을 손을 보아야 제가 원하는 조회를 할수 있을까요?
답변 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





