inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[개정판 2023-11-27] Spring Boot 3.x 를 이용한 RESTful Web Services 개발

게시물 관리를 위한 Post Entity 추가와 초기 데이터 생성

user와 post의 관계에 대해 명확하게 알고 싶습니다.

307

야무GYM

작성한 질문수 5

0

저 이외에도 여러 질문들이 있었지만, 확실하게 이해가 되지 않아 질문드립니다.

insert into post(description, user_id) 

이렇게 작성할 때, user_id 컬럼을 정의하지 않아도 자동으로 컬럼이 생기는게 이해가 가지 않습니다.

제가 추측해보기로는 User에서 기본키를 id라고 지정해주었고, @OneToMany, @ManyToOne 으로 두 클래스의 관계를 정의를 한 상태라고 봤습니다.

그 상태에서 클래스명_기본키명(즉, user_id)의 snake case로 작성하면 JPA가 이를 인식해서 자동으로 매핑시켜주는 것이 아닌가? 라고 추측을 해 봤는데.. 단순히 저의 생각이라 정리가 잘 되지 않습니다.

제 생각 중에 어디가 맞고 틀린지 짚어주셨으면 좋겠습니다.

 

 

 

 

rest-api spring-boot jpa

답변 2

0

Dowon Lee

안녕하세요, 이도원입니다.

말씀하신 내용처럼 JPA에 의해 Post와 User 사이에 의존 관계가 성립되어 있고, User (1) <-> Post (N) 관계로 설정되어 있습니다. User에서의 기본키가 id이고, Post에서도 id가 기본키인 입니다. User.jav에서는 posts를 OneToMnay로 설정(1:N) 하였고, 연결되는 필드명을 user로 하였습니다. Post에서는 User 빈을 참조하도록 선언되어 있고 이때는 ManyToOne(N:1)로 설정 되었습니다. 이 2개의 설정으로 User:Post의 설정은 1:N으로 설정되며, Post에서의 User 컬럼 참조키는 선언된 변수이름(user) + "_" + 기본키(id) = user_id 로 설정 됩니다. 만약, Post에서의 User user 선언을 userTest로 하신다면, Post 테이블의 컬럼은 user_test_id로 변경될 것입니다.

// User.java
@OneToMany(mappedBy = "user")
private List<Post> posts;
// Post.java
@ManyToOne(fetch = FetchType.LAZY)
@JsonIgnore
private User user;

위에서 예를 든 것처럼, User userTest로 선언할 경우는 아래와 같이 코드를 변경하시면 됩니다.

// User.java
@OneToMany(mappedBy = "userTest")
private List<Post> posts;
// Post.java
@ManyToOne(fetch = FetchType.LAZY)
@JsonIgnore
private User userTest;

생성 된 테이블은 아래와 같습니다.

image추가 질문사항 있으시면 다시 글 남겨주세요.

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

야무GYM님의 질문 관련하여 JPA에서 UserPost 사이의 연관 관계 및 user_id 컬럼의 자동 매핑에 대해 궁금하신 부분을 이해했습니다.

제공된 강의와 관련된 질문 중 이와 유사한 주제에 대해 설명하는 내용이 있어, 답변을 도와드리겠습니다.

User 의 List posts 컬렉션 조회시
이 링크에서는 Post를 등록하고 UserList<Post> posts 컬렉션 정보를 조회할 때, Post가 어떻게 User 컬렉션에 자동적으로 저장되는지에 대한 설명이 이루어집니다. 클래스 간의 관계 설정(@OneToMany, @ManyToOne) 덕분에 JPA가 연관 관계를 자동으로 처리해 주는 부분에 대해 이해할 수 있습니다.

유저 정보를 어떻게 유저 아이디만 넣고도 알게 되나요?
여기서는 Post 클래스에서 User 클래스를 어떻게 참조하게 되는지에 대한 설명이 이루어집니다. 특히 @ManyToOne 어노테이션을 활용하여 UserPost 사이의 관계 설정에 대한 이해를 돕는 내용이 포함되어 있습니다.

야무GYM님의 생각처럼, JPA에서는 엔티티 클래스간의 연관관계를 설정함으로써 (예: @OneToMany, @ManyToOne), 관계를 맺고 있는 테이블 간 적절한 외래 키를 자동으로 매핑합니다. 이 연관관계 매핑은 해당 엔티티 간의 관계를 객체 세계에서도 유지할 수 있게 해주며, RDB에서의 외래키 관계와 일치하게 됩니다. 따라서 질문하신 user_id 컬럼이 @ManyToOne 어노테이션을 통해 자동으로 생성 및 관리되는 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

0

야무GYM

아직도 잘 모르겠습니다. user_id를 정의하지 않고도 user_id가 생성되는게 궁금합니다.

user_name, user_ssn은 생성되지 않는 것을 확인 했는데, 유독 user_id만 생성되는 것이 외래키와 비슷하다고 생각해서 "참조클래스명_참조클래스id컬럼" 이것을 jpa가 인식하는 것인지 궁금합니다.

JPA

0

66

1

jpa dependency를 추가하고 SecurityConfig클래스에서 오류가 납니다.

0

76

1

웹 브라우저 400 bad request

0

76

1

@Size는 되는데 @Past는 안 됩니다.

0

70

1

pdf 자료는 없나요?

0

81

2

locale 정보가 null 이면 무조건 messages_ko.properties이 호출 되는 문제

0

94

2

Swagger 강의, Unable to infer base url 이거 뜨시는 분들 도움되시라고

0

125

1

강의에서나온 화면 피피티

0

163

1

HelloWorldBean 관련 에러

0

189

2

Swagger API 3.x 오류..

0

223

1

java: variable message not initialized in the default constructor 에러는 어찌하면 좋을까요?

1

284

1

현재 GIT에 올리신 소스를 실행해봤습니다.

0

195

2

고양이 소리가 귀엽네요 !!

0

141

2

git에서 소스받고 실습중인데

0

120

1

post가 안되요

0

107

1

한국어 같은 경우 언어코드인 messages_ko.properties 로 생성하는게 더 좋지 않나요?

0

169

2

리턴타입으로서 EntityModel<User> 와 ResponseEntity질문

0

109

1

예외처리쪽 관련 질문있습니다.

0

162

2

엔티티가 바로 응답으로 나가도 되나요??

0

235

2

안녕하세여 Cannot invoke "co.kr.joneconsulting.resfulservice.repository.PostRepository.save(Object)" because "this.postRepository" is null

0

146

2

사용자 등록하고 나서 H2 에서 보면 신규 사용자의 password, ssn 이 null 로 되어 있습니다.

0

145

2

ApplictionContext 질문

0

198

2

롬북이 안먹히는것같아요

0

161

1

인텔리제이에서스프링부트 파일 실행하면

0

243

1