인프런 커뮤니티 질문&답변

야무GYM님의 프로필 이미지

작성한 질문수

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

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

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

24.05.28 10:59 작성

·

124

·

수정됨

0

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

insert into post(description, user_id) 

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

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

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

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

 

 

 

 

답변 2

0

Dowon Lee님의 프로필 이미지
Dowon Lee
지식공유자

2024. 07. 21. 10:22

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

말씀하신 내용처럼 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 인턴님의 프로필 이미지

2024. 05. 28. 11:00

안녕하세요, 인프런 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 어노테이션을 통해 자동으로 생성 및 관리되는 것입니다.

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

야무GYM님의 프로필 이미지
야무GYM
질문자

2024. 05. 29. 15:38

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

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